中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

JS設計模式之狀態模的示例分析

發布時間:2021-06-26 10:27:25 來源:億速云 閱讀:183 作者:小新 欄目:web開發

這篇文章主要介紹了JS設計模式之狀態模的示例分析,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

1. 概述

當一個對象的內在狀態改變時允許改變其行為,這個對象看起來像是改變了其類。

2. 解決的問題

主要解決的是當控制一個對象狀態轉換的條件表達式過于復雜時的情況。把狀態的判斷邏輯轉移到表示不同的一系列類當中,可以把復雜的邏輯判斷簡單化。

function Context( _state ) {
 this.state = _state;
 this.request = function() {
  this.state.Handle( this );
 }
}
function ConcreteStateA() {
 this.Handle = function( context ) {
  console.log("A");
  context.state = new ConcreteStateB();
 }
}
function ConcreteStateB() {
 this.Handle = function( context ) {
  console.log("B");
  context.state = new ConcreteStateA();
 }
}
// 設置Context的初始狀態為ConcreteStateA
var context = new Context(new ConcreteStateA());
// 不斷地進行請求,同時更改狀態
context.request();
context.request();

狀態模式的使用場景也特別明確,有如下兩點:

一個對象的行為取決于它的狀態,并且它必須在運行時刻根據狀態改變它的行為。

一個操作中含有大量的分支語句,而且這些分支語句依賴于該對象的狀態。狀態通常為一個或多個枚舉常量的表示。

應用場景:

打電話有如下幾種狀態:獲取電話號碼、撥號中、通話中、通話結束。
這幾種狀態的順序是以次進行的,那么我們就可以根據這幾種狀態來實現狀態模式;

獲取電話號碼

JS設計模式之狀態模的示例分析

撥號中

JS設計模式之狀態模的示例分析

通話中

JS設計模式之狀態模的示例分析

通話結束

JS設計模式之狀態模的示例分析

不斷地去調用這個方法context.request(); 來判斷當前屬于那種狀態;

感謝你能夠認真閱讀完這篇文章,希望小編分享的“JS設計模式之狀態模的示例分析”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

js
AI

临泉县| 城固县| 日土县| 定西市| 安溪县| 图们市| 平远县| 永登县| 章丘市| 渑池县| 丰台区| 周至县| 东港市| 石台县| 德化县| 华容县| 嘉禾县| 许昌市| 秀山| 丰都县| 浑源县| 扎囊县| 玛曲县| 临泉县| 文登市| 墨脱县| 青岛市| 平遥县| 马公市| 巴塘县| 柳江县| 新竹市| 郁南县| 玉山县| 竹溪县| 诸暨市| 长沙县| 海原县| 麻栗坡县| 庐江县| 通江县|