前端常用設(shè)計(jì)模式

前端常見(jiàn)的設(shè)計(jì)模式主要有以下幾種:
1. 單例模式
2. 工廠模式
3. 策略模式
4. 代理模式
5. 觀察者模式
6. 模塊模式
7. 構(gòu)造函數(shù)模式
8. 混合模式

  • 單例模式
    這種設(shè)計(jì)模式的思想是確保一個(gè)類(lèi)只有唯一實(shí)例迄薄,一般用于全局緩存,比如全局window煮岁,唯一登錄浮窗等讥蔽。采用閉包的方式實(shí)現(xiàn)如下:
var single = (function(){
    let instance;

    function getInstance(){
    // 如果該實(shí)例存在,則直接返回人乓,否則就對(duì)其實(shí)例化
        if( instance=== undefined ){
            instance= new Construct();
        }
        return instance;
    }

    function Construct(){
        // ... 生成單例的構(gòu)造函數(shù)的代碼
    }

    return {
        getInstance : getInstance
    }
})();
  • 工廠模式
    工廠模式是創(chuàng)建對(duì)象的常用設(shè)計(jì)模式勤篮,為了不暴露創(chuàng)建對(duì)象的具體邏輯,將邏輯封裝在一個(gè)函數(shù)中色罚,這個(gè)函數(shù)就稱(chēng)為一個(gè)工廠碰缔。本質(zhì)上是一個(gè)負(fù)責(zé)生產(chǎn)對(duì)象實(shí)例的工廠。工廠模式根據(jù)抽象程度的不同可以分為:簡(jiǎn)單工廠戳护,工廠方法和抽象工廠金抡。通常用于根據(jù)權(quán)限生成角色的場(chǎng)景,抽象工廠方法的實(shí)現(xiàn)如下:
//安全模式創(chuàng)建的工廠方法函數(shù)
let UserFactory = function(role) {
  if(this instanceof UserFactory) {
    var s = new this[role]();
    return s;
  } else {
    return new UserFactory(role);
  }
}

//工廠方法函數(shù)的原型中設(shè)置所有對(duì)象的構(gòu)造函數(shù)
UserFactory.prototype = {
  SuperAdmin: function() {
    this.name = "超級(jí)管理員",
    this.viewPage = ['首頁(yè)', '通訊錄', '發(fā)現(xiàn)頁(yè)', '應(yīng)用數(shù)據(jù)', '權(quán)限管理']
  },
  Admin: function() {
    this.name = "管理員",
    this.viewPage = ['首頁(yè)', '通訊錄', '發(fā)現(xiàn)頁(yè)', '應(yīng)用數(shù)據(jù)']
  },
  NormalUser: function() {
    this.name = '普通用戶(hù)',
    this.viewPage = ['首頁(yè)', '通訊錄', '發(fā)現(xiàn)頁(yè)']
  }
}

//調(diào)用
let superAdmin = UserFactory('SuperAdmin');
let admin = UserFactory('Admin') 
let normalUser = UserFactory('NormalUser')
  • 策略模式
    策略模式的本意將算法的使用與算法的實(shí)現(xiàn)分離開(kāi)來(lái)腌且,避免多重判斷調(diào)用哪些算法梗肝。適用于有多個(gè)判斷分支的場(chǎng)景,如解決表單驗(yàn)證的問(wèn)題铺董。你可以創(chuàng)建一個(gè)validator對(duì)象巫击,有一個(gè)validate()方法。這個(gè)方法被調(diào)用時(shí)不用區(qū)分具體的表單類(lèi)型精续,它總是會(huì)返回同樣的結(jié)果——一個(gè)沒(méi)有通過(guò)驗(yàn)證的列表和錯(cuò)誤信息坝锰。實(shí)現(xiàn)方式如下:
// 對(duì)于vip客戶(hù)
function vipPrice() {
    this.discount = 0.5;
}
 
vipPrice.prototype.getPrice = function(price) {
  return price * this.discount;
}
// 對(duì)于老客戶(hù)
function oldPrice() {
    this.discount = 0.3;
}
 
oldPrice.prototype.getPrice = function(price) {
    return price * this.discount;
}
// 對(duì)于普通客戶(hù)
function Price() {
    this.discount = 1;
}
 
Price.prototype.getPrice = function(price) {
    return price ;
}

// 上下文,對(duì)于客戶(hù)端的使用
function Context() {
    this.name = '';
    this.strategy = null;
    this.price = 0;
}
 
Context.prototype.set = function(name, strategy, price) {
    this.name = name;
    this.strategy = strategy;
    this.price = price;
}
Context.prototype.getResult = function() {
    console.log(this.name + ' 的結(jié)賬價(jià)為: ' + this.strategy.getPrice(this.price));
}

var context = new Context();
var vip = new vipPrice();
context.set ('vip客戶(hù)', vip, 200);
context.getResult();   // vip客戶(hù) 的結(jié)賬價(jià)為: 100

var old = new oldPrice();
context.set ('老客戶(hù)', old, 200);
context.getResult();  // 老客戶(hù) 的結(jié)賬價(jià)為: 60

var Price = new Price();
context.set ('普通客戶(hù)', Price, 200);
context.getResult();  // 普通客戶(hù) 的結(jié)賬價(jià)為: 200
  • 代理模式
    代理模式是為其他對(duì)象提供一種代理重付,也就是當(dāng)其他對(duì)象直接訪問(wèn)該對(duì)象時(shí)顷级,如果開(kāi)銷(xiāo)較大,就可以通過(guò)這個(gè)代理層控制對(duì)該對(duì)象的訪問(wèn)确垫。常見(jiàn)的使用場(chǎng)景為懶加載弓颈,合并http請(qǐng)求和緩存帽芽。代理模式的實(shí)現(xiàn)如下:
(function(){
    // 目標(biāo)對(duì)象,是真正被代理的對(duì)象
    function Subject(){}
    Subject.prototype.request = function(){};

    function Proxy(realSubject){
        this.realSubject = realSubject;
    }
    Proxy.prototype.request = function(){
        this.realSubject.request();
    };
}());
  • 觀察者模式
    也叫發(fā)布訂閱模式翔冀,在這種模式中导街,一個(gè)訂閱者訂閱發(fā)布者,當(dāng)一個(gè)特定的事件發(fā)生的時(shí)候橘蜜,發(fā)布者會(huì)通知(調(diào)用)所有的訂閱者菊匿。實(shí)現(xiàn)代碼如下:
var EventCenter = (function(){
    var events = {};
    function on(event, handler){
        events[event] = events[event] || [];
        events[event].push({
            handler: handler
        });
    }

    function fire(event, args){
        if (!events[event]) {return}
        for (var i = 0; i < events[event].length; i++) {
            events[event][i].handler(args);
        }
    }

    function off(event){
        delete events[event];
    }

    return {
        on: on,
        fire: fire,
        off: off
    }
})();

EventCenter.on('event', function(data){
console.log('event received...');
});
  • 模塊模式
    模塊模式可以指定類(lèi)想暴露的屬性和方法,并且不會(huì)污染全局计福。采用閉包的形式,實(shí)現(xiàn)如下:
var Person = (function() {
    var name = 'xxx'
    function sayName() {
        console.log(name)
    }
    return{
        name: name,
        sayName: sayName
    }
})()
  • 構(gòu)造函數(shù)模式和混合模式
    構(gòu)造函數(shù)和混合模式就是js中繼承的兩種實(shí)現(xiàn)方式徽职,前者通過(guò)構(gòu)造函數(shù)的形式定義類(lèi)象颖,通過(guò)new新增實(shí)例。而后者是將構(gòu)造函數(shù)的引用屬性和方法放到其原型上姆钉,子類(lèi)是父類(lèi)原型的一個(gè)實(shí)例说订。
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市潮瓶,隨后出現(xiàn)的幾起案子陶冷,更是在濱河造成了極大的恐慌,老刑警劉巖毯辅,帶你破解...
    沈念sama閱讀 206,214評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件埂伦,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡思恐,警方通過(guò)查閱死者的電腦和手機(jī)沾谜,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,307評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)胀莹,“玉大人基跑,你說(shuō)我怎么就攤上這事∶柩妫” “怎么了媳否?”我有些...
    開(kāi)封第一講書(shū)人閱讀 152,543評(píng)論 0 341
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)荆秦。 經(jīng)常有香客問(wèn)我篱竭,道長(zhǎng),這世上最難降的妖魔是什么萄凤? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 55,221評(píng)論 1 279
  • 正文 為了忘掉前任室抽,我火速辦了婚禮,結(jié)果婚禮上靡努,老公的妹妹穿的比我還像新娘坪圾。我一直安慰自己晓折,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,224評(píng)論 5 371
  • 文/花漫 我一把揭開(kāi)白布兽泄。 她就那樣靜靜地躺著漓概,像睡著了一般。 火紅的嫁衣襯著肌膚如雪病梢。 梳的紋絲不亂的頭發(fā)上胃珍,一...
    開(kāi)封第一講書(shū)人閱讀 49,007評(píng)論 1 284
  • 那天,我揣著相機(jī)與錄音蜓陌,去河邊找鬼觅彰。 笑死,一個(gè)胖子當(dāng)著我的面吹牛钮热,可吹牛的內(nèi)容都是我干的填抬。 我是一名探鬼主播,決...
    沈念sama閱讀 38,313評(píng)論 3 399
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼隧期,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼飒责!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起仆潮,我...
    開(kāi)封第一講書(shū)人閱讀 36,956評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤宏蛉,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后性置,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體拾并,經(jīng)...
    沈念sama閱讀 43,441評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,925評(píng)論 2 323
  • 正文 我和宋清朗相戀三年蚌讼,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了辟灰。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,018評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡篡石,死狀恐怖芥喇,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情凰萨,我是刑警寧澤继控,帶...
    沈念sama閱讀 33,685評(píng)論 4 322
  • 正文 年R本政府宣布,位于F島的核電站胖眷,受9級(jí)特大地震影響武通,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜珊搀,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,234評(píng)論 3 307
  • 文/蒙蒙 一冶忱、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧境析,春花似錦囚枪、人聲如沸派诬。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,240評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)默赂。三九已至,卻和暖如春括勺,著一層夾襖步出監(jiān)牢的瞬間缆八,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,464評(píng)論 1 261
  • 我被黑心中介騙來(lái)泰國(guó)打工疾捍, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留奈辰,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,467評(píng)論 2 352
  • 正文 我出身青樓拾氓,卻偏偏與公主長(zhǎng)得像冯挎,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子咙鞍,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,762評(píng)論 2 345

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

  • 工廠模式類(lèi)似于現(xiàn)實(shí)生活中的工廠可以產(chǎn)生大量相似的商品,去做同樣的事情趾徽,實(shí)現(xiàn)同樣的效果;這時(shí)候需要使用工廠模式续滋。簡(jiǎn)單...
    舟漁行舟閱讀 7,718評(píng)論 2 17
  • 工廠模式 單體模式 模塊模式 代理模式 職責(zé)鏈模式 命令模式 模板方法模式 策略模式 發(fā)布-訂閱模式 中介者模式 ...
    HelloJames閱讀 1,005評(píng)論 0 6
  • 設(shè)計(jì)模式 單例 單例模式的核心思想是讓指定的類(lèi)只存在唯一一個(gè)實(shí)例。這意味著當(dāng)你第二次使用相同的類(lèi)去創(chuàng)建對(duì)象的時(shí)候孵奶,...
    代碼上的螞蟻閱讀 498評(píng)論 0 0
  • javascript設(shè)計(jì)模式與開(kāi)發(fā)實(shí)踐 設(shè)計(jì)模式 每個(gè)設(shè)計(jì)模式我們需要從三點(diǎn)問(wèn)題入手: 定義 作用 用法與實(shí)現(xiàn) 單...
    穿牛仔褲的蚊子閱讀 4,036評(píng)論 0 13
  • ??面向?qū)ο螅∣bject-Oriented了袁,OO)的語(yǔ)言有一個(gè)標(biāo)志朗恳,那就是它們都有類(lèi)的概念,而通過(guò)類(lèi)可以創(chuàng)建任意...
    霜天曉閱讀 2,093評(píng)論 0 6