日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

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

JavaScript設(shè)計(jì)模式之策略模式實(shí)現(xiàn)原理詳解

瀏覽:284日期:2023-10-24 18:23:25

俗話說,條條大路通羅馬。在現(xiàn)實(shí)生活中,我們可以采用很多方法實(shí)現(xiàn)同一個(gè)目標(biāo)。比如我們先定個(gè)小目標(biāo),先掙它一個(gè)億。我們可以根據(jù)具體的實(shí)際情況來完成這個(gè)目標(biāo)。

策略模式的定義

定義一系列的算法,把它們一個(gè)個(gè)封裝起來,并且使它們可以相互替換。

舉個(gè)例子:表單校驗(yàn)

在一個(gè)Web項(xiàng)目中,注冊、登錄等功能的實(shí)現(xiàn)都離不開表單提交。表單校驗(yàn)也是前端常常需要做的事。假設(shè)我們正在編寫一個(gè)注冊的頁面,在點(diǎn)擊提交按鈕之前,有如下幾條校驗(yàn)邏輯:

用戶名不可為空,不允許以空白字符命名,用戶名長度不能小于2位。 密碼長度不能小于6位。 正確的手機(jī)號(hào)碼格式。

也許,一開始我們會(huì)這么寫:

<html><head> <title>策略模式-校驗(yàn)表單</title> <meta content='text/html; charset=utf-8' http-equiv='Content-Type'></head><body> <form method='post' action='http://xxxx.com/api/register'> 用戶名:<input type='text' name='userName'> 密碼:<input type='text' name='password'> 手機(jī)號(hào)碼:<input type='text' name='phoneNumber'> <button type='submit'>提交</button> </form> <script type='text/javascript'> var registerForm = document.getElementById(’registerForm’); registerForm.onsubmit = function() { if (registerForm.userName.value === ’’) {alert(’用戶名不可為空’);return false; } if (registerForm.userName.value === ’’) {alert(’用戶名不可為空’);return false; } if (registerForm.userName.value.trim() === ’’) {alert(’用戶名不允許以空白字符命名’);return false; } if (registerForm.userName.value.trim().length < 2) {alert(’用戶名用戶名長度不能小于2位’);return false; } if (registerForm.password.value.trim().length < 6) {alert(’密碼長度不能小于6位’);return false; } if (!/^(13[0-9]|14[5|7]|15[0|1|2|3|5|6|7|8|9]|17[7]|18[0|1|2|3|5|6|7|8|9])d{8}$/.test(registerForm.phoneNumber.value)) {alert(’請輸入正確的手機(jī)號(hào)碼格式’);return errorMsg; } } </script></body></html>

這是一種很常見的編碼方式,但它有很明顯的缺點(diǎn):

registerForm.onsubmit 函數(shù)比較龐大,包含了很多if語句,這些語句要覆蓋所有的校驗(yàn)規(guī)則。 若校驗(yàn)規(guī)則有變,不得不深入到registerForm.onsubmit 函數(shù)的內(nèi)部實(shí)現(xiàn),違反開放-封閉原則。 算法的復(fù)用性差。

下面,讓我們來用策略模式重構(gòu)表單校驗(yàn)

策略模式:表單校驗(yàn)

<html><head> <title>策略模式-校驗(yàn)表單</title> <meta content='text/html; charset=utf-8' http-equiv='Content-Type'></head><body> <form method='post' action='http://xxxx.com/api/register'> 用戶名:<input type='text' name='userName'> 密碼:<input type='text' name='password'> 手機(jī)號(hào)碼:<input type='text' name='phoneNumber'> <button type='submit'>提交</button> </form> <script type='text/javascript'> // 策略對(duì)象 var strategies = { isNoEmpty: function (value, errorMsg) {if (value === ’’) { return errorMsg;} }, isNoSpace: function (value, errorMsg) {if (value.trim() === ’’) { return errorMsg;} }, minLength: function (value, length, errorMsg) {if (value.trim().length < length) { return errorMsg;} }, maxLength: function (value, length, errorMsg) {if (value.length > length) { return errorMsg;} }, isMobile: function (value, errorMsg) {if (!/^(13[0-9]|14[5|7]|15[0|1|2|3|5|6|7|8|9]|17[7]|18[0|1|2|3|5|6|7|8|9])d{8}$/.test(value)) { return errorMsg;} } } // 驗(yàn)證類 var Validator = function() { this.cache = []; } Validator.prototype.add = function(dom, rules) { var self = this; for(var i = 0, rule; rule = rules[i++];) {(function(rule) { var strategyAry = rule.strategy.split(’:’); var errorMsg = rule.errorMsg; self.cache.push(function() { var strategy = strategyAry.shift(); strategyAry.unshift(dom.value); strategyAry.push(errorMsg); return strategies[strategy].apply(dom, strategyAry); })})(rule) } }; Validator.prototype.start = function() { for(var i = 0, validatorFunc; validatorFunc = this.cache[i++];) {var errorMsg = validatorFunc();if (errorMsg) { return errorMsg;} } }; // 調(diào)用代碼 var registerForm = document.getElementById(’registerForm’); var validataFunc = function() { var validator = new Validator(); validator.add(registerForm.userName, [{strategy: ’isNoEmpty’,errorMsg: ’用戶名不可為空’ }, {strategy: ’isNoSpace’,errorMsg: ’不允許以空白字符命名’ }, {strategy: ’minLength:2’,errorMsg: ’用戶名長度不能小于2位’ }]); validator.add(registerForm.password, [ {strategy: ’minLength:6’,errorMsg: ’密碼長度不能小于6位’ }]); validator.add(registerForm.phoneNumber, [{strategy: ’isMobile’,errorMsg: ’請輸入正確的手機(jī)號(hào)碼格式’ }]); var errorMsg = validator.start(); return errorMsg; } registerForm.onsubmit = function() { var errorMsg = validataFunc(); if (errorMsg) {alert(errorMsg);return false; } } </script></body></html>

策略模式優(yōu)缺點(diǎn)

策略模式是一種常用且有效的設(shè)計(jì)模式。

策略模式可以有效避免多重條件選擇語句。 策略模式提供了對(duì)開放-封裝原則的完美支持,將方法封裝在獨(dú)立的strategy中,使得它們易于切換,易于理解,易于擴(kuò)展。 復(fù)用性高。

當(dāng)然,策略模式也有一些缺點(diǎn)

增加了許多策略類或者策略對(duì)象。 要使用策略模式,必須了解所有的strategy,違反了最少知識(shí)原則。

以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: JavaScript
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产欧美在线| 日韩精品视频一区二区三区| 中文字幕日韩亚洲| 久久亚洲国产精品一区二区| 综合干狼人综合首页| 日韩激情中文字幕| 国产精品亚洲一区二区在线观看 | 久久只有精品| 中文字幕在线高清| 欧美成人午夜| 亚洲三级网站| 911亚洲精品| 日本黄色精品| 一区二区视频欧美| 日韩精品成人在线观看| 久久精品国产99国产精品| 国产精品原创| 亚洲自拍另类| 国产精品极品| 久久久久网站| 日韩av中文字幕一区二区三区| 欧美国产极品| 九一成人免费视频| 日韩精品欧美精品| 欧美丰满日韩| 亚洲精品三级| 福利在线一区| 麻豆亚洲精品| 久久精品国内一区二区三区| 尹人成人综合网| 国产精品主播| 国产一区清纯| 国产精品对白久久久久粗| 自由日本语亚洲人高潮| 国产精品视频一区二区三区四蜜臂| 日韩专区精品| 亚洲三级毛片| 久久久夜夜夜| 国产另类在线| 亚洲色诱最新| 久久香蕉精品香蕉| 亚洲欧美日本视频在线观看| 精品九九在线| 亚洲一区二区三区无吗| 日韩欧美三级| 国产精品magnet| 亚洲免费中文| 精品捆绑调教一区二区三区 | 欧美日韩高清| 麻豆一区二区在线| 蜜桃av一区二区| 久久精品国产68国产精品亚洲| 国产伦精品一区二区三区视频| 一区免费视频| 日韩在线精品| 精品亚洲成人| 日韩国产欧美在线视频| 99国产精品视频免费观看一公开 | 亚欧成人精品| 免费av一区| 日韩av在线播放网址| 日本一区二区三区中文字幕| 91精品国产91久久久久久黑人| 国产精品一区二区免费福利视频| 蜜桃视频一区二区| 一区二区亚洲精品| 久久一区二区中文字幕| 国产一区二区三区四区二区| 日韩av中文字幕一区二区| 午夜电影亚洲| 久久久777| 91日韩在线| 国产精品国产三级在线观看| 亚洲人妖在线| 亚洲一区激情| 伊人久久大香线蕉av不卡| 综合日韩av| 色欧美自拍视频| 久久麻豆视频| 国产精品美女午夜爽爽| 国产三级精品三级在线观看国产| 免费日本视频一区| 香蕉久久国产| 欧美在线影院| 成人精品天堂一区二区三区| 麻豆视频在线观看免费网站黄 | 亚洲第一区色| 欧美va天堂| 亚洲精品一区二区在线看| 99久久夜色精品国产亚洲1000部| 鲁鲁在线中文| 国产白浆在线免费观看| 精品国产中文字幕第一页| 成人精品高清在线视频| 国产成人精品一区二区三区视频| 国产精品视频一区二区三区| 91伊人久久| 欧美三级第一页| 久久99青青| 久久精品五月| 欧洲精品一区二区三区| 亚洲1234区| 91精品国产福利在线观看麻豆| 精品国模一区二区三区| 欧美日韩国产免费观看视频| 久久成人国产| 少妇精品在线| 国产乱码精品一区二区亚洲| 欧美黄页在线免费观看| 国产成人免费视频网站视频社区| 国产v日韩v欧美v| 色吊丝一区二区| 午夜精品婷婷| 日韩1区2区3区| 国产精品99久久免费观看| 精品入口麻豆88视频| 日韩大片在线播放| 欧美网站在线| 日精品一区二区三区| 国产精品777777在线播放 | 久久99蜜桃| 日韩毛片视频| 免费人成精品欧美精品| 久久国内精品自在自线400部| 国产精品手机在线播放| 91一区二区三区四区| 狠狠爱成人网| 日韩高清不卡在线| 国产成人久久精品一区二区三区| 久久精品国语| 免费不卡在线观看| 国产欧美另类| 日韩精品麻豆| 综合激情五月婷婷| 国内一区二区三区| 日韩天堂av| 国产精品伦一区二区| 激情婷婷欧美| 国产日韩亚洲| 欧美性感美女一区二区| 欧美一区二区三区久久| 亚洲三级欧美| 亚洲精品三级| 精品国产免费人成网站| 免费成人性网站| 超碰在线99| 中文字幕成人| 国产精品毛片一区二区在线看| 99国产精品99久久久久久粉嫩| 国产精品日本一区二区三区在线| 日韩成人亚洲| 欧美精品三级在线| 欧美日韩国产一区二区三区不卡| 日韩激情av在线| 日韩不卡视频在线观看| 日韩av电影一区| 久久在线视频免费观看| 国产精品激情| 视频一区中文字幕| 国产a亚洲精品| 日韩中文字幕视频网| 久久精品国内一区二区三区水蜜桃| 日本中文字幕一区二区| 欧美日韩精品一区二区视频| 国产精品极品在线观看| 亚洲欧美日韩国产综合精品二区 | 欧美一区二区性| 国产精品美女在线观看直播| 久久xxxx| 激情欧美一区二区三区| 久久影院一区二区三区| 蜜臀av一区二区三区| 久久九九精品| 风间由美中文字幕在线看视频国产欧美| 亚洲欧美日本国产 | 日本精品在线中文字幕| 久久99蜜桃| 日韩av一区二| 日韩影院免费视频| 成人免费电影网址| 久久精品国产99国产精品| 日韩av在线免费观看不卡| 国产视频一区三区| 久久视频国产| 日韩在线第七页| 麻豆久久一区二区| 欧美日韩一区自拍| 综合视频一区| 午夜在线一区| 日韩视频二区| 久久久久久久久丰满| 日本久久黄色| 精品日本视频| 成人高清一区| 国产成人精品一区二区三区免费 | 欧美日韩精品免费观看视完整| 国产精品久久久亚洲一区| 日韩欧美中文字幕电影| 日韩在线成人| 亚洲一级淫片|