JS設(shè)計模式-其他1-原型模式 & 橋接模式

其他設(shè)計模式系列開始介紹前端不常用的設(shè)計模式
有哪些設(shè)計模式?

  1. 創(chuàng)建性模式
    原型模式
  2. 結(jié)構(gòu)型模式
    橋接模式 組合模式 享元模式
  3. 行為型模式
    策略模式 模板方法模式 職責(zé)鏈模式 命令模式 備忘錄模式 中介者模式 訪問者模式 解釋器模式

原型模式

概念

clone自己幌绍,生成一個新對象
java默認有clone接口,不用自己實現(xiàn)河哑。

JS中的應(yīng)用 Object.create()
// 一個原型 對象
let prototype = {
    getName: function () {
        return this.first + " " + this.last;
    },
    say: function () {
        alert("hello")
    }
}
// 基于原型創(chuàng)建x
let x = Object.create(prototype);
x.first = "A";
x.last = "B";
alert(x.getName());
x.say();
// 基于原型創(chuàng)建y
let y = Object.create(prototype);
y.first = "C";
y.last = "D";
alert(y.getName());
y.say();
對比JS中的原型prototype
  • prototype 可以理解為ES6 class 的一種底層原理實現(xiàn)
  • 而class是實現(xiàn)面向?qū)ο蟮幕A(chǔ)野来,并不是服務(wù)于某個模式
  • 若干年后ES6全面普及厕鹃,大家可能會忽略掉prototype
  • 但是Object.create卻會長久存在

橋接模式

概念
  • 用于把抽象化與實現(xiàn)化解耦
  • 使得二中可以獨立變化
    -(未找到JS中的經(jīng)典應(yīng)用)
demo

比如我們要畫這樣一幅圖


image.png

黃色圓圈 紅色圓圈 黃色三角 紅色三角 這樣四個圖形
代碼實現(xiàn)如果混合在一起一般是這個樣子的

class ColorShape {
    yellowCircle() {
        console.log("yellow circle")
    }
    redCircle() {
        console.log("red circle")
    }
    yellowTriangle() {
        console.log("yellow triangle")
    }
    redTriangle() {
        console.log("red triangle")
    }
}
// 測試
let cs = new ColorShape();
cs.yellowCircle()
cs.redCircle()
cs.yellowTriangle()
cs.redTriangle()

但是從前端模式來說芬位,我們一般是分離開的无拗,大概是這樣的


image.png

畫圖是畫圖,填充顏色是填充顏色昧碉,比較適合一些復(fù)雜性比較大的業(yè)務(wù)英染。
代碼實現(xiàn)是這個樣子的

class Color {
    constructor(name){
        this.name = name;
    }
}
class Shape {
    constructor(name, color){
        this.name = name;
        this.color = color;
    }
    draw(){
        console.log(`${this.color.name} ${this.name}`)
    }
}
// 測試代碼
let red = new Color("red");
let yellow = new Color("yellow");
let circle = new Shape("circle", red);
circle.draw();
let triangle = new Shape("triangle", yellow);
triangle.draw();
設(shè)計原則驗證
  • 抽象和實現(xiàn)分離
  • 符合開放封閉原則

本文資料來自慕課網(wǎng)-雙越老師-Javascript 設(shè)計模式系統(tǒng)講解與應(yīng)用視頻課程

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市被饿,隨后出現(xiàn)的幾起案子四康,更是在濱河造成了極大的恐慌,老刑警劉巖狭握,帶你破解...
    沈念sama閱讀 223,002評論 6 519
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件闪金,死亡現(xiàn)場離奇詭異,居然都是意外死亡论颅,警方通過查閱死者的電腦和手機哎垦,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,357評論 3 400
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來恃疯,“玉大人漏设,你說我怎么就攤上這事〗裢” “怎么了郑口?”我有些...
    開封第一講書人閱讀 169,787評論 0 365
  • 文/不壞的土叔 我叫張陵,是天一觀的道長盾鳞。 經(jīng)常有香客問我犬性,道長,這世上最難降的妖魔是什么腾仅? 我笑而不...
    開封第一講書人閱讀 60,237評論 1 300
  • 正文 為了忘掉前任乒裆,我火速辦了婚禮,結(jié)果婚禮上推励,老公的妹妹穿的比我還像新娘鹤耍。我一直安慰自己,他們只是感情好吹艇,可當(dāng)我...
    茶點故事閱讀 69,237評論 6 398
  • 文/花漫 我一把揭開白布惰蜜。 她就那樣靜靜地躺著,像睡著了一般受神。 火紅的嫁衣襯著肌膚如雪抛猖。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,821評論 1 314
  • 那天鼻听,我揣著相機與錄音财著,去河邊找鬼。 笑死撑碴,一個胖子當(dāng)著我的面吹牛撑教,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播醉拓,決...
    沈念sama閱讀 41,236評論 3 424
  • 文/蒼蘭香墨 我猛地睜開眼伟姐,長吁一口氣:“原來是場噩夢啊……” “哼收苏!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起愤兵,我...
    開封第一講書人閱讀 40,196評論 0 277
  • 序言:老撾萬榮一對情侶失蹤鹿霸,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后秆乳,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體懦鼠,經(jīng)...
    沈念sama閱讀 46,716評論 1 320
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,794評論 3 343
  • 正文 我和宋清朗相戀三年屹堰,在試婚紗的時候發(fā)現(xiàn)自己被綠了肛冶。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,928評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡扯键,死狀恐怖睦袖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情忧陪,我是刑警寧澤扣泊,帶...
    沈念sama閱讀 36,583評論 5 351
  • 正文 年R本政府宣布,位于F島的核電站嘶摊,受9級特大地震影響延蟹,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜叶堆,卻給世界環(huán)境...
    茶點故事閱讀 42,264評論 3 336
  • 文/蒙蒙 一阱飘、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧虱颗,春花似錦沥匈、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,755評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至畦粮,卻和暖如春散址,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背宣赔。 一陣腳步聲響...
    開封第一講書人閱讀 33,869評論 1 274
  • 我被黑心中介騙來泰國打工预麸, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人儒将。 一個月前我還...
    沈念sama閱讀 49,378評論 3 379
  • 正文 我出身青樓吏祸,卻偏偏與公主長得像,于是被迫代替她去往敵國和親钩蚊。 傳聞我的和親對象是個殘疾皇子贡翘,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,937評論 2 361