## 1.簡單工廠:
~~~
let factory = function (role) {
function superman() {
this.name ='超級管理員',
this.role = ['修改密碼', '發布消息', '查看主頁']
}
function commonMan() {
this.name = '普通游客',
this.role = ['查看主頁']
}
switch(role) {
case 'superman':
return new superman();
break;
case 'man':
return new commonMan();
break;
default:
throw new Error('參數錯誤')
}
}
let superman = factory('superman');
let man = factory('man');
~~~
在上述代碼中,factory就是一個簡單的工廠,該工廠中有二個構造函數分別對應不同的權限。我們只需要傳遞相應的參數就可以獲取一個實例對象了。工廠內部的構造函數有相似的地方,還可以進一步優化。
~~~
let factory = function (role) {
function User(obj) {
this.name = obj.name;
this.role = obj.role;
}
switch(role) {
case 'superman':
return new User({ name: '平臺用戶', role: ['主頁', '登錄頁'] })
break;
case 'man':
return new User({ name: '游客', role: ['登錄頁']})
break;
default:
throw new Error('參數錯誤')
}
}
let superman = factory('superman');
let man = factory('man');
~~~
簡單工廠的優點: 你只需要傳遞一個合法的參數,就可以獲取到你想要的對象,而無需知道創建的具體的細節。但是在函數內包含了所有對象的構造函數和判斷邏輯的代碼, 每次如果需要添加一個對象,那么我們需要新增一個構造函數,當我們需要維護的對象不是上面這2個,而是20個或者更多,那么這個函數將會成為超級函數,使得我們難以維護。所以簡單工廠模式只適用于在創建時對象數量少,以及邏輯簡單的情況。
- 視覺規范
- 色彩
- 文字
- 偏移
- 圖標
- 列表組件
- 表單組件
- 詳情組件
- 其他組件
- 研發規范
- 編碼規范
- 函數式編程
- 純函數
- 柯里化
- 函數組合
- 函子
- 面向對象編程
- 設計原則
- 單一職責原則
- 里氏替換原則
- 依賴倒置原則
- 接口隔離原則
- 開閉原則
- 迪米特原則
- 組合復用原則
- 設計模式
- 創建型模式
- 工廠模式
- 簡單工廠
- 工廠方法
- 抽象工廠
- 單例模式
- 建造者模式
- 原型模式
- 結構型模式
- 適配器模式
- 橋接模式
- 過濾器模式
- 組合模式
- 裝飾器模式
- 外觀模式
- 享元模式
- 代理模式
- 行為型模式
- 責任鏈模式
- 命令模式
- 解釋器模式
- 迭代器模式
- 中介者模式
- 備忘錄模式
- 觀察者模式
- 狀態模式
- 策略模式
- 模板模式
- 訪問者模式
- 組件設計規范
- 組件文檔編寫規范
- 版本管理規范