亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

JavaScript設計模式之工廠模式和抽象工廠模式定義與用法分析

發布時間:2020-10-10 10:49:19 來源:腳本之家 閱讀:132 作者:筱葭 欄目:web開發

本文實例講述了JavaScript設計模式之工廠模式和抽象工廠模式定義與用法。分享給大家供大家參考,具體如下:

1、工廠模式:

雖然Object構造函數和對象字面量都可以用來創建單個對象,但這個方式有個明顯的缺點:使用同一個接口創建很多對象,會產生大量重復的代碼。為了解決這個問題,開始使用工廠模式。

利用工廠模式,可以實現不指定特定的類而創建出對象,也就是說,不需要使用new關鍵字來創建特定類或子類的實例。

var TravelTeam = function(){};
TravelTeam.prototype = {
 register : function(model){
  var person;
  switch(type){
   case "student":
    person = new Student();
    break;
   case "teacher":
    person = new Teacher();
    break;
   default:
    person = new Doctor();
    break;
  }
  return person;
 }
}
var team = new TravelTeam();
team.register(student");

問題:大多數情形下使用沒有問題,但擴展性不好,如需要添加一些新的隊員類型,必須修改switch部分。

解決:工廠模式,把相同的部分單獨出來交給一個簡單的工廠對象:

var TeamFactory = {
 createTeam:function(type){
  var person;
  switch(type){
   case "student":
    person = new Student();
    break;
   case "teacher":
    person = new Teacher();
    break;
   default:
    person = new Doctor();
    break;
  }
  return person;
 }
}

TeamFactory是一個脫離于TravelTeam的單體,能降低耦合度,當需要添加一些新的隊員類型的時候,只要修改TeamFactory工廠單體對象就行。

var TravelTeam = function(){};
TravelTeam.prototype = {
 register:function(type){
  var person = TeamFactory.createTeam(type);
  return person;
 }
}

工廠模式的問題:雖然解決了創建多個相似對象的問題,但卻沒有解決對象識別的問題(即不知道對象的類型)。

解決:構造器模式,請見://www.jb51.net/article/144495.htm。

2、抽象工廠模式

在工廠模式的基礎上進行更高層次的抽象,根據共同的用途或主題來抽象出一個最高層基礎工廠類,其他具有相似行為的工廠類將繼承于此工廠類。

最典型的例子是了解HTML5與HTML4表單域的不同之處后,抽象出最高層的表單域工廠類,HTML5表單域工廠類和HTML4表單域工廠類都繼承自該類。

工廠模式與抽象工廠模式的不同:

① 當需要在代碼的其余所有部分通過屏蔽較為復雜的對象創建方法來簡化某些特定對象的創建過程時,使用工廠模式很適合;

② 當需要從現有代碼中的多個類中,根據這些類之間共有的目的或通用的主題,創建出一個額外的抽象層,以降低應用程序的其余開發工作的復雜性時,使用抽象工廠模式很適合。

更多關于JavaScript相關內容可查看本站專題:《javascript面向對象入門教程》、《JavaScript切換特效與技巧總結》、《JavaScript查找算法技巧總結》、《JavaScript錯誤與調試技巧總結》、《JavaScript數據結構與算法技巧總結》、《JavaScript遍歷算法與技巧總結》及《JavaScript數學運算用法總結》

希望本文所述對大家JavaScript程序設計有所幫助。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

镇平县| 沁阳市| 囊谦县| 葵青区| 时尚| 永定县| 宁安市| 泽库县| 新和县| 佳木斯市| 手机| 镇康县| 颍上县| 尖扎县| 攀枝花市| 白水县| 镇巴县| 靖西县| 合川市| 抚顺市| 安塞县| 遂宁市| 黄梅县| 资兴市| 邛崃市| 中江县| 绥棱县| 龙泉市| 新平| 青州市| 瑞昌市| 同江市| 搜索| 大英县| 苍南县| 塘沽区| 新营市| 红安县| 长宁县| 迁西县| 治县。|