JS-設(shè)計模式

設(shè)計模式:代碼經(jīng)驗的總結(jié)
設(shè)計模式都是面向?qū)ο蟮?/p>

工廠模式

工廠函數(shù)就是做一個對象創(chuàng)建的封裝曼玩,并將創(chuàng)建的對象return出去

 function newObj(name,age){
    var o = new Object();
    o.name = name;
    o.age = age;
    return o;
}
var obj = newObj();
單例模式:只允許存在一個實例的模式
 var Instance = (function(){
    var obj;
    return function(){
        if(obj === undefined) obj = new Date();
        return obj;
    }
})();
var ibs = Instance();
觀察者模式

又稱發(fā)布訂閱者模式,經(jīng)典案例:事件監(jiān)聽祷杈,一個元素同時監(jiān)聽多個同類型事件呀狼,元素對象即為發(fā)布者楼熄,每一個事件處理函數(shù)即為訂閱者恢暖。

策略模式

策略模式的定義是:定義一系列的算法,把它們一個個封裝起來仇奶,并且使它們可以相互替換,從而避免很多if語句比驻,曾經(jīng)學(xué)過最簡單的策略模式雛形就是使用數(shù)組的方式解決傳入數(shù)字得到對應(yīng)星期幾問題的算法该溯。

比如公司的年終獎是根據(jù)員工的工資和績效來考核的,績效為A的人别惦,年終獎為工資的4倍狈茉,績效為B的人,年終獎為工資的3倍掸掸,績效為C的人氯庆,年終獎為工資的2倍

 var obj = {
    "A": function(salary) {
        return salary * 4;
    },
    "B" : function(salary) {
        return salary * 3;
    },
    "C" : function(salary) {
        return salary * 2;
    }
};
var calculateBouns =function(level,salary) {
    return obj[level](salary);
};
console.log(calculateBouns('A',10000)); // 40000
代理模式

代理模式(Proxy),為其他對象提供一種代理以控制對這個對象的訪問扰付,為了不暴露執(zhí)行對象的部分代碼

 //三個對象
//用戶委托快捷方式打開exe
//為了不暴露執(zhí)行對象的部分代碼
//男孩委托快遞小哥給女孩送禮物
var girl = function(name){
    this.name = name;
}
//隱藏復(fù)雜堤撵,不愿意修改的的方法
var boy = function(girl){
    this.girl = girl;
    this.send = function(gift){
        alert("你好:"+this.girl.name+",給你一個"+gift);
    }
}
var proxyBro = function(girl){
    this.send = function(gift){
        new boy(girl).send(gift);
    }
}
var pro = new proxyBro(new girl("Lisa"));
pro.send("么么噠");
pro.send("玫瑰花");
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市羽莺,隨后出現(xiàn)的幾起案子实昨,更是在濱河造成了極大的恐慌,老刑警劉巖盐固,帶你破解...
    沈念sama閱讀 222,183評論 6 516
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件荒给,死亡現(xiàn)場離奇詭異,居然都是意外死亡刁卜,警方通過查閱死者的電腦和手機志电,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,850評論 3 399
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來长酗,“玉大人溪北,你說我怎么就攤上這事。” “怎么了之拨?”我有些...
    開封第一講書人閱讀 168,766評論 0 361
  • 文/不壞的土叔 我叫張陵茉继,是天一觀的道長。 經(jīng)常有香客問我蚀乔,道長烁竭,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,854評論 1 299
  • 正文 為了忘掉前任吉挣,我火速辦了婚禮派撕,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘睬魂。我一直安慰自己终吼,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 68,871評論 6 398
  • 文/花漫 我一把揭開白布氯哮。 她就那樣靜靜地躺著际跪,像睡著了一般。 火紅的嫁衣襯著肌膚如雪喉钢。 梳的紋絲不亂的頭發(fā)上姆打,一...
    開封第一講書人閱讀 52,457評論 1 311
  • 那天,我揣著相機與錄音肠虽,去河邊找鬼幔戏。 笑死,一個胖子當(dāng)著我的面吹牛税课,可吹牛的內(nèi)容都是我干的闲延。 我是一名探鬼主播,決...
    沈念sama閱讀 40,999評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼伯复,長吁一口氣:“原來是場噩夢啊……” “哼慨代!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起啸如,我...
    開封第一講書人閱讀 39,914評論 0 277
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎氮惯,沒想到半個月后叮雳,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,465評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡妇汗,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,543評論 3 342
  • 正文 我和宋清朗相戀三年帘不,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片杨箭。...
    茶點故事閱讀 40,675評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡寞焙,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情捣郊,我是刑警寧澤辽狈,帶...
    沈念sama閱讀 36,354評論 5 351
  • 正文 年R本政府宣布,位于F島的核電站呛牲,受9級特大地震影響刮萌,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜娘扩,卻給世界環(huán)境...
    茶點故事閱讀 42,029評論 3 335
  • 文/蒙蒙 一着茸、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧琐旁,春花似錦涮阔、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,514評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至验懊,卻和暖如春擅羞,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背义图。 一陣腳步聲響...
    開封第一講書人閱讀 33,616評論 1 274
  • 我被黑心中介騙來泰國打工减俏, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人碱工。 一個月前我還...
    沈念sama閱讀 49,091評論 3 378
  • 正文 我出身青樓娃承,卻偏偏與公主長得像,于是被迫代替她去往敵國和親怕篷。 傳聞我的和親對象是個殘疾皇子历筝,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,685評論 2 360

推薦閱讀更多精彩內(nèi)容

  • 工廠模式 單體模式 模塊模式 代理模式 職責(zé)鏈模式 命令模式 模板方法模式 策略模式 發(fā)布-訂閱模式 中介者模式 ...
    HelloJames閱讀 1,012評論 0 6
  • 策略模式簡述 策略模式定義一系列的算法,把它們一個個封裝起來廊谓,并且使它們可以相互替換梳猪。 策略模式的優(yōu)點:一、策略模...
    5d18ee6b5b1c閱讀 1,941評論 0 1
  • 設(shè)計模式 單例 單例模式的核心思想是讓指定的類只存在唯一一個實例蒸痹。這意味著當(dāng)你第二次使用相同的類去創(chuàng)建對象的時候春弥,...
    代碼上的螞蟻閱讀 505評論 0 0
  • 單例模式 適用場景:可能會在場景中使用到對象,但只有一個實例叠荠,加載時并不主動創(chuàng)建匿沛,需要時才創(chuàng)建 最常見的單例模式,...
    Obeing閱讀 2,076評論 1 10
  • 2018任務(wù)繁重,今年打算把重點放在js的深入上,往大前端方向發(fā)展.年初有空看完了《JavaScript高級程序設(shè)...
    丶丶夏天閱讀 799評論 1 2