亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

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

JavaScript設計模式之策略模式實現原理詳解

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

俗話說,條條大路通羅馬。在現實生活中,我們可以采用很多方法實現同一個目標。比如我們先定個小目標,先掙它一個億。我們可以根據具體的實際情況來完成這個目標。

策略模式的定義

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

舉個例子:表單校驗

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

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

也許,一開始我們會這么寫:

<html><head> <title>策略模式-校驗表單</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'> 手機號碼:<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(’請輸入正確的手機號碼格式’);return errorMsg; } } </script></body></html>

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

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

下面,讓我們來用策略模式重構表單校驗

策略模式:表單校驗

<html><head> <title>策略模式-校驗表單</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'> 手機號碼:<input type='text' name='phoneNumber'> <button type='submit'>提交</button> </form> <script type='text/javascript'> // 策略對象 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;} } } // 驗證類 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;} } }; // 調用代碼 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: ’請輸入正確的手機號碼格式’ }]); var errorMsg = validator.start(); return errorMsg; } registerForm.onsubmit = function() { var errorMsg = validataFunc(); if (errorMsg) {alert(errorMsg);return false; } } </script></body></html>

策略模式優缺點

策略模式是一種常用且有效的設計模式。

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

當然,策略模式也有一些缺點

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

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 黄色小视频在线观看 | 国产香蕉在线精彩视频 | 免费人成xvideoscom中文 | 国产久热美女福利视频 | 海天翼精品一区二区三区 | 起碰97 | 国产精品福利久久 | 伊人久久中文字幕 | aaaaaa级特色特黄的毛片 | 亚洲这里只有精品 | 亚洲精品一线观看 | 好硬好湿好爽再深一点h视频 | 免费成年人在线观看视频 | 欧美 亚洲 一区 | 国产一级网站 | 91热久久免费精品99 | 婷婷久久五月天 | 黑人操日本妞 | 欧美一级毛片不卡免费观看 | 免费国产一级特黄aa大片在线 | 日韩高清中文字幕 | 国产成人一区二区精品非洲 | 中文精品久久久久国产网址 | 亚洲 日本 欧美 日韩精品 | 亚州三级 | 99精品国产自在现线观看 | 色综合免费视频 | 国产精品成人观看视频免费 | 无码中文字幕乱在线观看 | 亚洲国产精品综合久久网络 | a级毛片在线免费观看 | 亚洲综合在线最大成人 | 国产成人在线播放 | 久久草在线观看视频 | 成人福利免费在线观看 | aa级黄色大片 | 在线亚视频 | 国产一区二区三区免费看 | 成人午夜免费视频免费看 | 成人私拍福利视频在线 | 国产免费a级片 |