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

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

javascript設(shè)計(jì)模式 ? 狀態(tài)模式原理與用法實(shí)例分析

瀏覽:61日期:2023-11-02 15:34:33

本文實(shí)例講述了javascript設(shè)計(jì)模式 ? 狀態(tài)模式原理與用法。分享給大家供大家參考,具體如下:

介紹:狀態(tài)模式用于解決系統(tǒng)中復(fù)雜對象的狀態(tài)轉(zhuǎn)換以及不同狀態(tài)下行為的封裝問題。狀態(tài)模式將一個對象的狀態(tài)從該對象中分離出來,使得對象狀態(tài)可以靈活變化。

定義:允許一個對象在其內(nèi)部狀態(tài)改變時改變它的行為,對象看起來似乎修改了它的類,其別名為狀態(tài)對象,狀態(tài)模式是一種對象行為型模式。

場景:在很多情況下我們的頁面需要做一些狀態(tài)判斷,是否注冊,是否登錄,剩余金額是否大于500等等,我們通常是在組件中通過if…else…來做不同的處理,這種方式耦合嚴(yán)重不滿足單一職責(zé)原則。如何解決這個問題呢,這一節(jié)我們利用狀態(tài)模式來解決對象的狀態(tài)切換。

示例:

var Dialog = function(){ var _state = null; this.setState = function(state){ _state = state; } this.getState = function(){ return _state; }} var ShowState = function(){ this.doAction = function(dialog){ console.log('對Dialog設(shè)置顯示狀態(tài):'); dialog.setState(this); } this.toString = function(){ console.log('顯示中......'); }} var HideState = function(){ this.doAction = function(dialog){ console.log('對Dialog設(shè)置隱藏狀態(tài):'); dialog.setState(this); } this.toString = function(){ console.log('已隱藏......'); }} var dialog = new Dialog(); var showState = new ShowState();var hideState = new HideState(); showState.doAction(dialog);//對Dialog設(shè)置顯示狀態(tài):dialog.getState().toString();//顯示中......hideState.doAction(dialog);//對Dialog設(shè)置隱藏狀態(tài)dialog.getState().toString();//已隱藏......

這個例子里Dialog對象有兩種狀態(tài),顯示和隱藏,我把兩種狀態(tài)提取出來,使得狀態(tài)的管理更加靈活。在這個例子里面Dialog稱之為環(huán)境類,環(huán)境類又稱為上下文類,他擁有多種狀態(tài)。環(huán)境類內(nèi)部需要維護(hù)一個state對象用來定義當(dāng)前狀態(tài)。HideState,ShowState稱之為狀態(tài)類,對應(yīng)環(huán)境類的一個具體狀態(tài),toString稱之為狀態(tài)類的行為,每一個狀態(tài)類的行為都有所不同。

狀態(tài)模式總結(jié):

優(yōu)點(diǎn):* 封裝了狀態(tài)的轉(zhuǎn)換規(guī)則,在狀態(tài)模式中可以將狀態(tài)的轉(zhuǎn)換代碼封裝在環(huán)境類或者具體狀態(tài)類中,方便對狀態(tài)轉(zhuǎn)換代碼進(jìn)行管理。* 將所有與某個狀態(tài)有關(guān)的行為放到一個類中,只需要注入一個不同的狀態(tài)對象即可使環(huán)境對象擁有不同行為

缺點(diǎn):* 狀態(tài)模式的使用必然會增加系統(tǒng)中狀態(tài)類的數(shù)量,導(dǎo)致開銷變大。* 結(jié)構(gòu)設(shè)計(jì)交付為咋,使用不當(dāng)會導(dǎo)致程序結(jié)構(gòu)和代碼混亂,增加系統(tǒng)設(shè)計(jì)難度。

適用場景:* 對象的行為依賴于它的狀態(tài),狀態(tài)改變將導(dǎo)致行為的變化* 在代碼中包含大量與對象狀態(tài)有關(guān)的條件語句

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

更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《javascript面向?qū)ο笕腴T教程》、《JavaScript錯誤與調(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)文章:
主站蜘蛛池模板: 久久久久久久国产精品影院 | 91九九| 欧美成人高清性色生活 | 国产精品吹潮在线播放 | 欧美熟videos肥婆 | 97成人在线 | www.欧美成人| 欧美性xxxx极品高清 | 午夜亚洲精品 | 久久久青草 | 一区二区三区视频网站 | 欧美午夜激情影院 | 日本三级香港三级三级人 | 在线亚洲精品视频 | 经典香港a毛片免费观看 | 久久久久久综合对白国产 | 手机在线观看亚洲国产精品 | 草草日| 午夜精品一区二区三区在线观看 | 99综合视频| 欧美刺激午夜性久久久久久久 | 亚洲视频一区在线 | 青青热在线精品视频免费 | 中文字幕在线一区二区三区 | 青青热久久国产久精品秒播 | 亚洲一级毛片免费观看 | 亚洲欧美卡通动漫丝袜美腿 | 久久久高清免费视频 | 久久免费视频网站 | 精品毛片免费看 | 日韩人成| 国产精品青草久久福利不卡 | 亚洲欧美性视频 | www.一区二区三区.com | 国产精品青草久久久久福利99 | 99色视频在线 | 综合久久久久久中文字幕 | 免费看成人毛片 | 国产三级精品91三级在专区 | 毛片视频在线免费观看 | 亚洲人成综合网站在线 |