成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

您的位置:首頁技術文章
文章詳情頁

怎樣用Javascript實現策略模式

瀏覽:6日期:2023-10-02 10:40:01
概述

策略模式是JavaScript設計模式中行為型的設計模式;

定義:

定義一系列算法,并將這些算法各自封裝成策略類(方法),然后將不變的部分和變化的部分分離開來,并且這些算法可以相互替換

白話解釋:

實際上所謂的策略模式就是指根據不同的策略來執行不同的方法,是不是很類似與if-else分支判斷;但是策略模式是用來解決多重條件判斷語句的;

代碼實現

需求:

年終將至,某公司決定提前發年終獎,但是年終獎的計算是有一定的規則的,年終獎的多少跟績效考核密切相關;所以某公司的年終獎方案是這樣的:

績效考核為S的員工,年終獎是個人月工資的4倍;

績效考核為A的員工,年終獎是個人月工資的3倍;

績效考核為B的員工,年終獎是個人月工資的2倍;

看到這里讓你開始編寫程序,一般大部分的代碼是這樣的:

function calculateBonus(level,salary){ if(level === ’S’){return salary*4; }if(level === ’A’){return salary*3 } if(level === ’B’){return salary*2 }}console.log(calculateBonus('S',14000)); //56000console.log(calculateBonus('A',10000)); //30000console.log(calculateBonus('B',5000)); //10000

上面的代碼用來解決當前需求固然沒有問題,但是在程序設計的角度來說,上面的代碼是還有可以優化的點的;因為該方法相對來說比較龐大,有很多的分支判斷,缺乏彈性;如果年終獎方案改了,需要增加一個C方案呢?那是不是又得去方法里面加分支判斷呢?這就違反了開放封閉原則;

優化:

var strategies = { 'S':function(salary){return salary*4 }, 'A':function(salary){return salary*3; }, 'B':function(salary){return salary*2 }}var calculateBonus =function(level,salary){ return strategies[level](salary);} console.log(calculateBonus('S',14000)); //56000console.log(calculateBonus('A',10000)); //30000console.log(calculateBonus('B',5000)); //10000

通過優化上述代碼之后,上面就是用策略模式來進行改造代碼的,我們可以看到我們定義了一個策略對象,然后calculateBonus根據用戶傳入的等級和工資即可算出年終獎的金額,經過改造之后,代碼的結構變得更加簡潔;

在web開發中,登錄頁的注冊、登錄等功能都是需要進行表單提交的;然而在提交的過程中肯定要進行校驗和篩選,不符合校驗規則的將不能直接提交;在沒有學習設計模式之前我們的校驗可能也是跟上面一樣都是多重if分支判斷,然后我們現在用策略模式來實現一個表單校驗:

<!DOCTYPE html><html lang='en'><head> <meta charset='UTF-8'> <meta name='viewport' content='width=device-width, initial-scale=1.0'> <meta http-equiv='X-UA-Compatible' content='ie=edge'> <title>Document</title></head><body><form action='http:// xxx.com/register' method='post'> 請輸入用戶名:<input type='text' name='userName'/ > 請輸入密碼:<input type='text' name='password'/ > 請輸入手機號碼:<input type='text' name='phoneNumber'/ > <button>提交</button></form></body><script>// 定義策略類算法校驗規則var strategies = {isNonEmpty: function( value, errorMsg ){ if ( value === ’’ ){return errorMsg; }},minLength: function( value, length, errorMsg ){ if ( value.length < length ){return errorMsg; }},isMobile: function( value, errorMsg ){ if ( !/(^1[3|5|8][0-9]{9}$)/.test( value ) ){return errorMsg; }} }; //Validator 類 var Validator = function(){// 保存校驗規則this.cache = []; }; //添加校驗規則的方法 Validator.prototype.add = function( dom, rules ){var self = this;for ( var i = 0, rule; rule = rules[ i++ ]; ){ (function( rule ){//將校驗規則對象中的strategy屬性的值進行分割var strategyAry = rule.strategy.split( ’:’ );var errorMsg = rule.errorMsg;self.cache.push(function(){ //將校驗規則對象中的strategy屬性的第一個值返回回來裝進strategy中 var strategy = strategyAry.shift(); //組成參數 strategyAry.unshift( dom.value ); //組裝參數 strategyAry.push( errorMsg ); //找到策略對象執行方法裝進cache變量中 return strategies[ strategy ].apply( dom, strategyAry );});console.log(strategyAry); })( rule )} }; //開始校驗方法 Validator.prototype.start = function(){for ( var i = 0, validatorFunc; validatorFunc = this.cache[ i++ ]; ){ //循環cache執行方法校驗 var errorMsg = validatorFunc(); //如果執行策略對象方法中返回了errorMsg,就說明方法已經報錯(沒有通過校驗規則) if ( errorMsg ){return errorMsg; }} }; //調用校驗 var registerForm = document.getElementById( ’registerForm’ ); //定義方法可以自定義添加校驗規則 var validataFunc = function(){//實例化對象var validator = new Validator();//自定義添加校驗規則validator.add( registerForm.userName, [{ strategy: ’isNonEmpty’, errorMsg: ’用戶名不能為空’}, { strategy: ’minLength:6’, errorMsg: ’用戶名長度不能小于10 位’}]);validator.add( registerForm.password, [{ strategy: ’minLength:6’, errorMsg: ’密碼長度不能小于6 位’}]);//調用方法循環執行校驗var errorMsg = validator.start();return errorMsg; } //點擊提交按鈕(提交事件) registerForm.onsubmit = function(){//執行上面自定義的校驗方法var errorMsg = validataFunc();//如果errorMsg存在,即代表校驗沒有通過if ( errorMsg ){ alert ( errorMsg ); return false;} };</script></html>

我們可以通過策略模式來解決表單校驗大規模重復if-else判斷等問題,上面的代碼注釋我已經給的很詳細了,學習設計模式一定要去細品代碼,學習思路;反正策略模式的一個主要思路就是通過定義一系列的算法,然后傳入參數,根據不同的參數來執行不同的算法規則;

總結

優點:

1、利用組合、委托和多態技術和思想,可以避免多重條件選擇語句;

2、將算法封裝在獨立的策略類里,使得易于切換,易于理解,易于擴展;

3、策略模式可以復用在系統的其他地方,從而避免重復的復制粘貼工作; 

缺點:

1、程序中會增加許多策略類或者策略對象;

2、使用策略類必須要對所有的策略類算法了解清楚,否則不知道怎么選擇。

以上就是JavaScript策略模式的詳細內容,更多關于JavaScript策略模式的資料請關注好吧啦網其它相關文章!

標簽: JavaScript
相關文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
国产精品色一区二区三区| 日本韩国精品在线| 国产欧美激情| 久久精品免费在线观看| 久久国产乱子精品免费女| 亚洲特色特黄| 欧美成人女星排行榜| 美女网站色91| 久久久成人网| 亚洲电影在线播放| 亚洲黄色影片| 成人免费在线播放视频| 欧美一区二区三区四区夜夜大片| 3d动漫精品啪啪| 免费不卡在线视频| 美日韩精品免费| 亚洲久本草在线中文字幕| 欧美精品一区二区视频 | 精品久久久久久无| 国产美女娇喘av呻吟久久| 日本丰满少妇一区二区三区| 亚洲国产欧美一区二区三区丁香婷| 亚洲二区免费| 亚洲日穴在线视频| 影音先锋久久资源网| 国产欧美一区二区精品性色| www.在线成人| 精品99999| heyzo一本久久综合| 日韩欧美一区中文| 国产成a人亚洲精| 日韩午夜激情av| 国产成人精品www牛牛影视| 欧美一级片在线观看| 中文有码久久| 精品va天堂亚洲国产| 福利电影一区二区| 亚洲精品一区二区三区香蕉| 成人av中文字幕| 精品国产精品一区二区夜夜嗨| 国产高清精品网站| 欧美一级在线视频| 成人黄动漫网站免费app| 日韩你懂的在线观看| 成人小视频免费在线观看| 亚洲高清不卡一区| 日本一区二区电影| 国产精品v欧美精品v日韩精品| 亚洲人成精品久久久久| 亚洲欧洲另类| 亚洲一区二区在线免费观看视频| 亚洲欧美卡通另类91av| 日韩国产欧美在线播放| 欧美日韩精品久久久| 国产福利精品导航| 国产亚洲欧美在线| 亚洲欧洲日韩综合二区| 亚洲成a人在线观看| 色婷婷国产精品| 亚洲图片激情小说| 午夜在线视频观看日韩17c| 日韩精品福利网| 日韩一区二区三区精品视频| 91首页免费视频| 国产精品美女久久久久高潮| 国产欧美日韩亚洲| 日产国产欧美视频一区精品 | 久久精品欧美一区二区三区麻豆| 日韩一级免费| 看国产成人h片视频| 精品久久久久一区| 亚洲每日更新| 激情文学综合插| 久久久精品影视| 亚洲精品久久| 久草精品在线观看| 久久精品无码一区二区三区| 国产欧美日韩综合一区在线观看 | 91福利精品视频| 99re这里只有精品视频首页| 亚洲欧美另类在线| 在线观看国产精品网站| 成人ar影院免费观看视频| 亚洲色图欧美激情| 91久久香蕉国产日韩欧美9色| 成人午夜av在线| 亚洲精品写真福利| 欧美日韩国产首页| 午夜精品电影| 日本视频免费一区| 精品国产欧美一区二区| 亚洲少妇自拍| 国产成人在线免费| 一区二区三区精品久久久| 制服丝袜中文字幕亚洲| 亚洲激情另类| 国产精品一级在线| 亚洲免费在线播放| 欧美一级在线观看| 99在线精品视频在线观看| 国产麻豆视频一区二区| 亚洲图片欧美激情| 制服.丝袜.亚洲.中文.综合| 一区在线视频观看| 国产一二精品视频| 亚洲人午夜精品天堂一二香蕉| 欧美日韩精品一区二区三区蜜桃| 亚洲成人中文| 国产成人精品免费| 亚洲成a人片综合在线| 久久精品亚洲精品国产欧美kt∨| 91福利视频在线| 精品动漫3d一区二区三区免费版| 精品在线播放午夜| 国产精品欧美极品| 欧美三电影在线| 在线观看成人av| 成人网页在线观看| 亚洲成人自拍偷拍| 国产日韩欧美麻豆| 在线亚洲高清视频| 亚洲高清激情| 成人av网址在线| 男人的天堂久久精品| 国产精品护士白丝一区av| 在线免费精品视频| 91久久黄色| av成人免费在线| 久久精品国产久精国产| 伊人夜夜躁av伊人久久| 2021中文字幕一区亚洲| 欧美无砖砖区免费| 国产农村妇女精品一二区| 欧美sm重口味系列视频在线观看| 国产一区二区不卡老阿姨| 偷拍日韩校园综合在线| 日韩一区在线看| 久久亚洲精华国产精华液| 欧美性猛交xxxx黑人交| 亚洲一区二区网站| 国产精品激情| 91在线丨porny丨国产| 国产做a爰片久久毛片| 午夜精品久久久久久| 亚洲图片激情小说| 中文在线一区二区| 26uuu精品一区二区在线观看| 欧美日韩视频不卡| 色婷婷久久久亚洲一区二区三区| 亚洲国产网站| 欧美国产先锋| 成人av资源下载| 国产精品18久久久久| 美日韩一区二区三区| 亚洲v中文字幕| 一区二区三区在线观看欧美| 国产精品久久精品日日| 国产欧美一二三区| 精品福利av导航| 欧美一级淫片007| 欧美美女黄视频| 欧美性色综合网| 欧美视频自拍偷拍| 欧洲av一区二区嗯嗯嗯啊| 一本一道综合狠狠老| 国产伦精品一区二区| 亚洲激情视频| 激情综合久久| 日韩美女主播在线视频一区二区三区| 国产欧美一区视频| 91麻豆精品国产91久久久久久 | 成人免费黄色大片| 国产精品88av| 成人性视频网站| 成人免费毛片app| 成人免费视频一区二区| 国产69精品久久久久777| 精品亚洲国内自在自线福利| 美女网站一区二区| 久久99国产乱子伦精品免费| 激情综合网av| 激情丁香综合五月| 激情综合网天天干| 国产精品一二三在| 国产成人一区在线| 国产成人在线免费观看| 亚洲国产精品久久久久秋霞影院| 亚洲一区二区偷拍精品| 欧美日韩国产高清| 91在线国产福利| 国产寡妇亲子伦一区二区| 国产精品1区2区3区在线观看| 麻豆精品一区二区三区| 日本强好片久久久久久aaa| 亚洲国产精品影院| 性做久久久久久免费观看| 亚洲成国产人片在线观看| 天堂精品中文字幕在线| 奇米色一区二区三区四区| 日韩va亚洲va欧美va久久|