欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

javascript設(shè)計(jì)模式 – 裝飾模式原理與應(yīng)用實(shí)例分析

 更新時(shí)間:2020年04月14日 09:01:10   作者:李小強(qiáng)  
這篇文章主要介紹了javascript設(shè)計(jì)模式 – 裝飾模式,結(jié)合實(shí)例形式分析了javascript裝飾模式基本概念、原理、應(yīng)用場(chǎng)景及操作注意事項(xiàng),需要的朋友可以參考下

本文實(shí)例講述了javascript設(shè)計(jì)模式 – 裝飾模式原理與應(yīng)用。分享給大家供大家參考,具體如下:

介紹:裝飾模式可以在不改變一個(gè)對(duì)象本身功能的基礎(chǔ)上給對(duì)象增加額外的新行為。在現(xiàn)實(shí)生活中,這種情況也到處存在,例如一張照片,可以不改變照片本身,通過(guò)增加一個(gè)相框,使其具有防潮的功能。裝飾模式是一種用于替代繼承的技術(shù),它使用對(duì)象之間的關(guān)聯(lián)關(guān)系來(lái)取代繼承關(guān)系。

定義:動(dòng)態(tài)的給一個(gè)對(duì)象增加一些額外的職責(zé),就增加對(duì)象功能來(lái)說(shuō),裝飾模式比生成子類(lèi)實(shí)現(xiàn)更為靈活。裝飾模式是一種對(duì)象結(jié)構(gòu)模型。

場(chǎng)景:我們現(xiàn)有一個(gè)Circle類(lèi)用來(lái)畫(huà)一個(gè)圓,新的需求要求畫(huà)一個(gè)紅色的圓,又一個(gè)新的需求要求我們畫(huà)一個(gè)半徑20的圓,又一個(gè)新的需求要求我們畫(huà)一個(gè)紅色的,半徑20的圓。
如何設(shè)計(jì)才能讓我們的代碼來(lái)兼容這樣的需求呢?我們首先給Circle類(lèi)包裝一個(gè)顏色的相框,這個(gè)相框用來(lái)改變圓的顏色。再給Circle類(lèi)包裝一個(gè)大小的相框,這個(gè)相框用來(lái)改變圓的大小。通過(guò)不同的相框組合來(lái)達(dá)到想要的效果。

示例:

var Circle = function(){
  this.draw = function(){
    console.log('畫(huà)圓');
  };
}
 
var ColorDecorator = function(circle){
  this.circle = circle;
  this.draw = function(){
    this.circle.draw();
    setColor();
    return this.circle;
  }
  function setColor(){
    console.log('紅色');
  }
}
 
var RadiusDecorator = function(circle){
  this.circle = circle;
  this.draw = function(){
    this.circle.draw();
    setRadius();
  }
  function setRadius(){
    console.log('半徑:20px')
  }
}
 
var circle = new Circle();
 
var redCricle = new ColorDecorator(circle);
 
var radiusCricle = new RadiusDecorator(circle);
 
var radiusRedCircle = new RadiusDecorator(new ColorDecorator(circle));
 
//輸出:
circle.draw();  //畫(huà)圓
 
redCricle.draw(); //畫(huà)圓 紅色
 
radiusCricle.draw(); //畫(huà)圓 半徑:20px
 
radiusRedCircle.draw(); //畫(huà)圓 紅色 半徑:20px

以上就是裝飾模式的示例,比較好懂,在不改變Circle類(lèi)基礎(chǔ)上進(jìn)行擴(kuò)展,通過(guò)包裝一層來(lái)實(shí)現(xiàn)新特性。降低了系統(tǒng)的耦合度。與繼承結(jié)構(gòu)相比,裝飾模式大大減少了子類(lèi)的個(gè)數(shù),讓系統(tǒng)擴(kuò)展起來(lái)更加方便,而且更容易維護(hù)。RadiusDecorator,ColorDecorator稱(chēng)為裝飾類(lèi),他們的引入將大大簡(jiǎn)化系統(tǒng)的設(shè)計(jì),他也是裝飾模式的核心。

裝飾模式總結(jié):

優(yōu)點(diǎn):
* 便于擴(kuò)展一個(gè)對(duì)象的功能,裝飾模式比繼承更加具有靈活性,不會(huì)導(dǎo)致類(lèi)的個(gè)數(shù)急劇增加。
* 可以通過(guò)一種動(dòng)態(tài)的方式來(lái)擴(kuò)展一個(gè)對(duì)象的功能。
* 可以對(duì)一個(gè)對(duì)象進(jìn)行多次裝飾,通過(guò)不同的裝飾類(lèi)組合,可以創(chuàng)造很多不同行為的組合,得到功能更強(qiáng)大的對(duì)象

缺點(diǎn):
* 使用裝飾模式過(guò)程中會(huì)產(chǎn)生很多小對(duì)象,一定程度影響程序性能。
* 裝飾模式特別靈活,同時(shí)也意味著更加容易出錯(cuò),排除復(fù)雜度也不低。

適用場(chǎng)景:
* 不影響對(duì)象的基礎(chǔ)下進(jìn)行擴(kuò)展,添加職責(zé)

感興趣的朋友可以使用在線(xiàn)HTML/CSS/JavaScript代碼運(yùn)行工具http://tools.jb51.net/code/HtmlJsRun測(cè)試上述代碼運(yùn)行效果。

更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專(zhuān)題:《javascript面向?qū)ο笕腴T(mén)教程》、《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)

希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。

相關(guān)文章

最新評(píng)論