JavaScript設計模式之策略模式

来源:https://www.cnblogs.com/jofun/archive/2018/03/05/8509336.html
-Advertisement-
Play Games

所謂“條條道路通羅馬”,在現實中,為達到某種目的往往不是只有一種方法。比如掙錢養家:可以做點小生意,可以打分工,甚至還可以是偷、搶、賭等等各種手段。在程式語言設計中,也會遇到這種類似的情況,要實現某種功能可以有多種方案選擇。比如,在很多地圖類軟體上,你想從A地點到達B地點時,為你提供幾種交通工具的選... ...


所謂“條條道路通羅馬”,在現實中,為達到某種目的往往不是只有一種方法。比如掙錢養家:可以做點小生意,可以打分工,甚至還可以是偷、搶、賭等等各種手段。在程式語言設計中,也會遇到這種類似的情況,要實現某種功能可以有多種方案選擇。比如,在很多地圖類軟體上,你想從A地點到達B地點時,為你提供幾種交通工具的選擇,可以查看每種交通工具的所需費用和時間。在程式語言設計中,把這種設計模式叫做策略模式。

 

策略模式的定義:策略模式是指對一系列的演算法定義,並將每一個演算法封裝起來,而且使它們還可以相互替換。

 

主要解決問題:在有多種演算法相似的情況下,使用 if...else 所帶來的複雜和難以維護。

 

從上面兩點可以知道,策略模式是通過定義一系列的演算法,並對其進行封裝,使其可以相互替換使用,目的是消除多層if...else語句嵌套的問題。這裡的定義一系列的演算法的意思是:你可以將每一種方案封裝成函數或者是類的形式。

先看個輸出今天是星期幾的例子:

//獲取當天是星期幾函數
function getDay(day){
    if(day === 0){
        console.log('今天是星期日');
    }
                
    if(day === 1){
        console.log('今天是星期一');
    }
                
    if(day === 2){
        console.log('今天是星期二');
    }
                
    if(day === 3){
        console.log('今天是星期三');
    }
                
    if(day === 4){
        console.log('今天是星期四');
    }
                
    if(day === 5){
        console.log('今天是星期五');
    }
                
    if(day === 6){
        console.log('今天是星期六');
    }
};
            
var day = new Date().getDay();
            
getDay(day);

 

上面的代碼完全正常,使用起來一點問題都沒有,但不易於維護。用策略模式重構上面的代碼:

//定義策略類
var Strategies = (function(){
                
    function A(){
        console.log('今天是星期一');
    };
                
    function B(){
        console.log('今天是星期二');
    };
                
    function C(){
        console.log('今天是星期三');
    };
                
    function D(){
        console.log('今天是星期四');
    };
                
    function E(){
        console.log('今天是星期五');
    };
                
    function F(){
        console.log('今天是星期六');
    };
                
    function G(){
        console.log('今天是星期日');
    };
                
    return {
        getDay1: A,
        getDay2: B,
        getDay3: C,
        getDay4: D,
        getDay5: E,
        getDay6: F,
        getDay0: G
    }

})();
            
//展示當天是星期幾的函數
function alertWeekDay(){
    var d = new Date().getDay();
                
    //根據變數d選擇調用Strategies類的方法
    Strategies["getDay" + d]();
};

alertWeekDay();

 

大伙看到這段代碼的時候,是否認為上面的代碼比這個用什麼策略模式的簡潔的多了去了?從代碼量的角度看,確實是這樣。但現實是,作為開發者我們有80%的時間是在維護舊的代碼,剩下的20%才是寫新的代碼,所以寫出可維護的代碼同樣很重要。改用策略模式後的代碼雖然代碼量增加了,但更易於維護了。為什麼更容易維護了呢?假如某一天W3C把Date對象的getDay()函數改成為從0~6分別對應星期一到星期日(而不是現在的0表示星期日,1~6分別對象星期一到星期六),第一段用if寫的代碼是不是要把所用if結構的代碼都要改一遍,但第二段代碼只需修改Strategies類里return的對象的方法順序即可,那個更易於維護一眼便知。

 

當然上面是基於面向對象的方式使用的策略模式,大家都知道JavaScript沒有類的概念,所以上面不是正在意義上的JavaScript語言策略模式。在JavaScript中,函數是一等對象,可以將函數當作一個變數傳遞到函數內部執行,所以JavaScript語言是天生自帶策略模式的哦!下麵看看真正的JavaScript語言策略模式:

function getDay0(e){
    console.log('今天是星期日:' + e);
};
            
function getDay1(e){
    console.log('今天是星期一:' + e);
};
            
function getDay2(e){
    console.log('今天是星期二:' + e);
};
            
function getDay3(e){
    console.log('今天是星期三:' + e);
};
            
function getDay4(e){
    console.log('今天是星期四:' + e);
};
            
function getDay5(e){
    console.log('今天是星期五:' + e);
};
            
function getDay6(e){
    console.log('今天是星期六:' + e);
};
            
//展示備忘事件函數
function alertRemindEvents(fn, events){
     fn(events);
};
            
alertRemindEvents(getDay3, "今天中午媽媽沒時間做飯,我要自己去買菜做飯了。");

 

策略模式的優缺點:

優點: 1、演算法可以自由切換。 2、避免使用多重條件判斷。 3、擴展性良好。

缺點: 1、策略類會增多。 2、所有策略類都需要對外暴露。

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • JSONP(JSON with Padding)是JSON的一種“使用模式”,可用於解決主流瀏覽器的跨域數據訪問的問題。由於同源策略,一般來說位於 server1.example.com 的網頁無法與不是 server1.example.com的伺服器溝通,而 HTML 的<script> 元素是一 ...
  • 後端開發:1、高級java軟體架構師實戰培訓視頻教程2、大型SpringMVC,Mybatis,Redis,Solr,Nginx,SSM分散式電商項目視頻教程3、Spark Streaming實時流處理項目實戰4、Java校招面試 Google面試官親授5、Java開發企業級許可權管理系統6、Java ...
  • FormData部分: 先new FormData對象 :let somedata = new FormData(),然後將數據添加進去,這裡我們使用append()進行添加。 這裡舉一個上傳頭像的例子: let token = localStorage.token; let img = $(".f ...
  • 1、正常的拖拽是用絕對定位absolute來實現的,可是bootstrap的模態框是用relative,為了統一更改方便,就照著相對定位來實現拖拽效果。 當然,沒有做限定,想怎麼脫就怎麼脫,,,哦不,是拖、、、拖,不是你想的那樣的,好吧,就是你想的那樣。 可是判斷限制了一下發現還有問題,拖著拖著就跑 ...
  • ES6學習筆記(1)參考書《ECMAScript 6入門》http://es6.ruanyifeng.com/let和const命令let 總結1.聲明變數基本使用方法與var 相同 不同點 a.在代碼塊中使用let聲明的變數只在代碼塊中有效,代碼塊外無法訪問,而用var聲明的在代碼塊外也可以訪問。 ...
  • 使用例子: 添加: 在window.location.href後加上a=1和b=2。 修改之後將會變成xxxxxxxxxx?a=1&b=2。 獲取參數: ...
  • 原因是mui框架的有個css樣式 *{ -webkit-user-select: none; } *{ -webkit-user-select: none; } 其作用是禁掉用戶可以選中頁面中的內容。 添加以下style樣式即可 input{ -webkit-user-select: auto; } ...
  • 問題 後圖省事使用 來添加native配置,結果run時報錯。 ps:安裝的 需要native的插件 不變且多次link會一直給幾個配置文件里添加代碼,會出現多餘代碼,所以link一次就好 解決 原因是link配置不完全, 文件少了一行配置: link可能會有問題,最穩健的還是插件文檔中提到的手動方 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...