亚洲免费在线视频-亚洲啊v-久久免费精品视频-国产精品va-看片地址-成人在线视频网

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

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

瀏覽:75日期: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)文章:
主站蜘蛛池模板: 国产成人精品magnet | 性欧美美国级毛片 | 欧美成人欧美激情欧美风情 | 欧美xxxx性xxxxx高清视频 | 国产乱码精品一区二区三区中 | 国产欧美一区二区 | 9191久久久久视频 | 国产精品区在线12p 国产精品人成 | 在线观看国产精品入口 | 精品一久久香蕉国产二月 | 日韩精品一区二区三区高清 | 国产成人lu在线视频 | 国产精品久久久久久福利 | 欧美在线综合视频 | 日本一级爽毛片在线看 | 老头老太做爰xxx视频 | 欧美日韩中文国产一区二区三区 | 99re在线视频精品 | 欧美性猛交xxxxx按摩国内 | 亚洲综合色就色手机在线观看 | 91精品视频免费 | 午夜免费理论片a级 | 成人网免费看 | 日韩欧美在线观看视频一区二区 | 日韩精品免费一区二区 | 国产呦精品一区二区三区网站 | 老司机精品影院一区二区三区 | 中文字幕在线永久 | 欧美三级欧美一级 | 欧美激情久久久久久久大片 | 99久久精品费精品国产一区二区 | 国产午夜毛片一区二区三区 | 精品久久免费观看 | avtt制服丝袜 | 黄毛片一级毛片 | 性色xxx| 国产三及 | 国产成人精品一区二区三区 | 国产三级国产精品国产国在线观看 | 一区二区三区在线 | 日本 | 成人在线网址 |