溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

如何使用javascript中的抽象工廠模式

發(fā)布時(shí)間:2020-08-04 15:02:58 來源:億速云 閱讀:108 作者:小豬 欄目:web開發(fā)

這篇文章主要講解了如何使用javascript中的抽象工廠模式,內(nèi)容清晰明了,對(duì)此有興趣的小伙伴可以學(xué)習(xí)一下,相信大家閱讀完之后會(huì)有幫助。

介紹:基于工廠模式,繼續(xù)升級(jí)。來解決工廠模式存在多個(gè)工廠類的問題。主要的思想是將一些相關(guān)的產(chǎn)品組成一個(gè)產(chǎn)品族,由同一個(gè)工廠來統(tǒng)一生產(chǎn)。

定義:抽象工廠模式提供一個(gè)創(chuàng)建一系列相關(guān)或相互依賴的接口,而無須指定他們具體的類。抽象工廠模式又稱kit模式,它是一種對(duì)象創(chuàng)建型模式。

場(chǎng)景:還是上面的Dialog類,如果繼續(xù)向后發(fā)展,會(huì)有各種各樣的彈窗,如果新增一個(gè)彈窗包含了notice和toast。這樣的情況下,我們不需要再單獨(dú)新增一個(gè)工廠類。我們需要對(duì)這一類具有同樣特征的彈窗進(jìn)行聚合。

示例:

var Dialog = function(){
  this.show = function(){
    console.log(this.name + ' is show -> ' + this.element);
  }
};
 
Dialog.createNotice = function(){
  var _dialog = new Dialog();
  _dialog.element = '<div>notice</div>';
  _dialog.name = 'notice';
  return _dialog;
};
 
Dialog.createToast = function(){
  var _dialog = new Dialog();
  _dialog.element = '<div>toast</div>';
  _dialog.name = 'toast';
  return _dialog;
};
 
Dialog.createWarnin = function(){
  var _dialog = new Dialog();
  _dialog.element = '<div>warnin</div>';
  _dialog.name = 'warnin';
  return _dialog;
};
 
 
var Factory = {};
 
Factory.ConvergeFactory = function(){
  return {
    getNotice: function(){
      return Dialog.createNotice();
    },
    getToast: function(){
      return Dialog.createToast();
    },
 getWarnin: function(){
     return Dialog.createWarnin();
 }
  }
}
 
var converge = Factory.ConvergeFactory();
var notice = converge.getNotice();
var toast = converge.getToast();
var warnin = converge.getWarnin();
notice.show(); //notice is show -> <div>notice</div>
toast.show(); //toast is show -> <div>toast</div>
warnin.show(); //warnin is show -> <div> warnin </div>

抽象工廠模式主要解決的是Factory過多的問題,經(jīng)過組合產(chǎn)生新的產(chǎn)品族。

我們這里的舉例有些牽強(qiáng),換個(gè)場(chǎng)景,如果我們有很多按鈕啊,輸入框之類的組件,要通過單獨(dú)的工廠進(jìn)行獲取實(shí)例。

抽象工廠模式就是將特定的組件經(jīng)過聚合產(chǎn)生新的工廠。

但這樣的結(jié)果好還是不好,增加新的產(chǎn)品族時(shí)遵守了開關(guān)原則,但是在對(duì)新的產(chǎn)品族結(jié)構(gòu)進(jìn)行修改時(shí)就會(huì)發(fā)現(xiàn)需要從業(yè)務(wù)到工廠到子類挨個(gè)修改,也違反了開關(guān)原則。

所以抽象工廠模式的使用場(chǎng)景需要特別嚴(yán)謹(jǐn),要在設(shè)計(jì)之初全面考慮,不要輕易對(duì)產(chǎn)品族結(jié)構(gòu)進(jìn)行修改。

抽象工廠模式總結(jié):

優(yōu)點(diǎn):
* 當(dāng)產(chǎn)品族被使用后,隔離了具體類的實(shí)現(xiàn)
* 新增產(chǎn)品族時(shí)很方便,無需修改已有結(jié)構(gòu),符合開關(guān)原則

缺點(diǎn):
* 修改已有產(chǎn)品族結(jié)構(gòu)時(shí),需要修改工廠以及所有使用的業(yè)務(wù)代碼。

前面我們介紹了三種工廠模式,在前端使用的過程中,要靈活的應(yīng)用,使用其思想而不是生搬硬套。

工廠模式核心是通過不同參數(shù)來生成不同產(chǎn)品。抽象工廠和工廠是在實(shí)際場(chǎng)景下進(jìn)行優(yōu)化而來。

這也提醒我們,要不斷地對(duì)代碼進(jìn)行思考,進(jìn)行優(yōu)化。

看完上述內(nèi)容,是不是對(duì)如何使用javascript中的抽象工廠模式有進(jìn)一步的了解,如果還想學(xué)習(xí)更多內(nèi)容,歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI