色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術(shù)文章
文章詳情頁

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

瀏覽:25日期:2023-11-04 09:34:30

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

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

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

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

示例:

var Circle = function(){ this.draw = function(){ console.log(’畫圓’); };} 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(); //畫圓 redCricle.draw(); //畫圓 紅色 radiusCricle.draw(); //畫圓 半徑:20px radiusRedCircle.draw(); //畫圓 紅色 半徑:20px

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

裝飾模式總結(jié):

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

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

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

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

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

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

標(biāo)簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: 欧美一区二三区 | 一级毛片成人免费看a | 国产精品一区二区三区高清在线 | 性色xxx| 国产亚洲一区在线 | 中文字幕日韩精品有码视频 | 成年人网站免费 | 亚洲国产欧美在线不卡中文 | 99久热在线精品视频观看 | 久久久久日韩精品无 | 亚洲国产成人久久 | 在线视频一区二区三区 | 不卡一区二区在线 | 暖暖视频日韩欧美在线观看 | 91视频国产91久久久 | 亚洲依依成人综合在线网址 | 免费国产成人18在线观看 | 亚洲日韩中文字幕天堂不卡 | 成人18免费观看的软件 | 久久九九精品视频 | 成人黄色在线视频 | 欧美在线播放成人免费 | 91成人在线视频 | 92精品国产自产在线观看 | 国产91综合 | 天堂8中文在线最新版在线 天堂8资源8在线 | 欧美日本亚洲国产一区二区 | 成 人免费va视频 | 顶级毛片在线手机免费看 | 台湾三级香港三级经典三在线 | 国产美女午夜精品福利视频 | 成年人在线免费观看视频网站 | 黄色三级网址 | 久草视频免费在线播放 | 中文字幕在线永久 | 欧美一级毛片在线播放 | 特级aaaaaaaaa毛片免费视频 | 99精彩免费观看 | 毛片免费观看日本中文 | 国产精品色内内在线播放 | 欧美片欧美日韩国产综合片 |