學(xué)習(xí)JavaScript設(shè)計(jì)模式之策略模式
把不變的部分和變化的部分隔開是每個(gè)設(shè)計(jì)模式的主題。
- 條條大路通羅馬。我們經(jīng)常會(huì)遇到解決一件事情有多種方案,比如壓縮文件,我們可以使用zip算法、也可以使用gzip算法。其靈活多樣,我們可以采用策略模式解決。
一、定義
定義一系列的算法,把它們一個(gè)個(gè)封裝起來,并且使它們可以相互替換。
基于策略類模式的程序至少由兩部分組成。第一個(gè)部分是一組策略類,策略類封裝了具體的算法,并負(fù)責(zé)具體的計(jì)算過程。第二個(gè)部分是環(huán)境類Context,Context接收客戶的請(qǐng)求,隨后把請(qǐng)求委托給某一個(gè)策略類。
二、示例
計(jì)算獎(jiǎng)金??冃镾的發(fā)放4倍工資,績效為A的發(fā)放3倍工資,績效為B的發(fā)放2倍工資。
var strategies = { "S": function(salary) { return salary * 4; }, "A": function(salary) { return salary * 3; }, "B": function(salary) { return salary * 2; } }; // 接收請(qǐng)求 var calculateBonus = function(level, salary) { return strategies[level](salary); }; // 測試 console.log(calculateBonus("S", 20000)); console.log(calculateBonus("A", 20000)); console.log(calculateBonus("B", 20000));
三、延伸:表單驗(yàn)證
/* 校驗(yàn)策略對(duì)象 */ var validateStrategies = { isEmpty: function (val, errorMsg) { if (!val) { return errorMsg; } }, isURL: function (val, errorMsg) { if (!new RegExp("^(http:\\/\\/|https:\\/\\/)?([\\w\\-]+\\.)+[\\w\\-]+(\\/[\\w\\-\\.\\/?\\@\\%\\!\\&=\\+\\~\\:\\#\\;\\,]*)?$").test(val)) { return errorMsg; } }, isEmail: function (val, errorMsg) { if (!new RegExp('\\w+((-\\w+)|(\\.\\w+))*\\@[A-Za-z0-9]+((\\.|-)[A-Za-z0-9]+)*\\.[A-Za-z0-9]+').test(val)) { return errorMsg; } }, isMaxLength: function (val, length, errorMsg) { if (val.length > length) { return errorMsg; } }, isMinLength: function (val, length, errorMsg) { if (val.length < length) { return errorMsg; } } }; /* validator類 */ var validator = function () { // 緩存驗(yàn)證策略 this.cache = []; }; /** * 添加要驗(yàn)證的策略 * @param dom 要驗(yàn)證的dom元素 * @param rules 驗(yàn)證規(guī)則 */ validator.prototype.add = function (dom, rules) { var self = this; for (var i = 0, rule; rule = rules[i++];) { (function (rule) { var strategyAry = rule.strategy.split(":"); // ["isMaxLength", "10"] var errorMsg = rule.errorMsg; // "內(nèi)容長度不能超過10" self.cache.push(function () { var strategy = strategyAry.shift(); // "isMaxLength" strategyAry.unshift(dom.value); // ["1@qq", "10"] strategyAry.push(errorMsg); // ["1@qq", "10", "內(nèi)容長度不能超過10"] return validateStrategies[strategy].apply(dom, strategyAry); }); })(rule); } }; /* 開始校驗(yàn) */ validator.prototype.start = function () { for (var i = 0, validateFunc; validateFunc = this.cache[i++];) { var errorMsg = validateFunc(); if (errorMsg) { return errorMsg; } } }; // 測試 <label for="email">郵箱:</label><input type="text" name="email" value="1@qq"> var validatorInstance = new validator(); validatorInstance.add( document.getElementsByName("email")[0], [{ strategy: "isEmpty", errorMsg: "內(nèi)容不能為空" },{ strategy: "isMaxLength:10", errorMsg: "內(nèi)容長度不能超過10" },{ strategy: "isEmail", errorMsg: "email格式不對(duì)" }]); errorMsg = validatorInstance.start();
希望本文所述對(duì)大家學(xué)習(xí)javascript程序設(shè)計(jì)有所幫助。
- js單例模式的兩種方案
- JS實(shí)現(xiàn)單例模式的6種方案匯總
- javascript 單例模式演示代碼 javascript面向?qū)ο缶幊?/a>
- JavaScript的單例模式 (singleton in Javascript)
- 輕松掌握J(rèn)avaScript單例模式
- [js高手之路]單例模式實(shí)現(xiàn)模態(tài)框的示例
- JavaScript設(shè)計(jì)模式之策略模式詳解
- javascript設(shè)計(jì)模式--策略模式之輸入驗(yàn)證
- JavaScript設(shè)計(jì)模式之策略模式實(shí)例
- 學(xué)習(xí)JavaScript設(shè)計(jì)模式(策略模式)
- javascript單例模式與策略模式實(shí)例詳解
相關(guān)文章
bootstrap實(shí)現(xiàn)的自適應(yīng)頁面簡單應(yīng)用示例
這篇文章主要介紹了bootstrap實(shí)現(xiàn)的自適應(yīng)頁面簡單應(yīng)用,結(jié)合具體實(shí)例形式分析了基于bootstrap的列表布局結(jié)構(gòu)頁面實(shí)現(xiàn)與使用技巧,需要的朋友可以參考下2017-03-03淺談js繼承的實(shí)現(xiàn)及公有、私有、靜態(tài)方法的書寫
下面小編就為大家?guī)硪黄獪\談js繼承的實(shí)現(xiàn)及公有、私有、靜態(tài)方法的書寫。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-10-10javascript支持IE和firefox(FF)的漸變透明效果
DataThis可以發(fā)送任何標(biāo)簽,這個(gè)標(biāo)簽沒有ID也可以,因?yàn)橛玫氖亲远x屬性。2008-10-10JavaScript構(gòu)造函數(shù)原理及實(shí)現(xiàn)流程解析
這篇文章主要介紹了JavaScript構(gòu)造函數(shù)原理及實(shí)現(xiàn)流程解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-11-11