电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

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

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

瀏覽:158日期: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
相關文章:
主站蜘蛛池模板: 辐射仪|辐射检测仪|辐射巡测仪|个人剂量报警仪|表面污染检测仪|辐射报警仪|辐射防护网 | 短信营销平台_短信群发平台_106短信发送平台-河南路尚 | 上海电子秤厂家,电子秤厂家价格,上海吊秤厂家,吊秤供应价格-上海佳宜电子科技有限公司 | 杭州成人高考_浙江省成人高考网上报名| 油漆辅料厂家_阴阳脚线_艺术漆厂家_内外墙涂料施工_乳胶漆专用防霉腻子粉_轻质粉刷石膏-魔法涂涂 | 自动化生产线-自动化装配线-直流电机自动化生产线-东莞市慧百自动化有限公司 | 胜为光纤光缆_光纤跳线_单模尾纤_光纤收发器_ODF光纤配线架厂家直销_北京睿创胜为科技有限公司 - 北京睿创胜为科技有限公司 | 铁盒_铁罐_马口铁盒_马口铁罐_铁盒生产厂家-广州博新制罐 | 高通量组织研磨仪-多样品组织研磨仪-全自动组织研磨仪-研磨者科技(广州)有限公司 | 理化生实验室设备,吊装实验室设备,顶装实验室设备,实验室成套设备厂家,校园功能室设备,智慧书法教室方案 - 东莞市惠森教学设备有限公司 | 食药成分检测_调料配方还原_洗涤剂化学成分分析_饲料_百检信息科技有限公司 | 我车网|我关心的汽车资讯_汽车图片_汽车生活! | 【同风运车官网】一站式汽车托运服务平台,验车满意再付款 | 变色龙PPT-国内原创PPT模板交易平台 - PPT贰零 - 西安聚讯网络科技有限公司 | 消电检公司,消电检价格,北京消电检报告-北京设施检测公司-亿杰(北京)消防工程有限公司 | 涡轮流量计_LWGY智能气体液体电池供电计量表-金湖凯铭仪表有限公司 | 中医中药治疗血小板减少-石家庄血液病肿瘤门诊部 | 深圳天际源广告-形象堆头,企业文化墙,喷绘,门头招牌设计制作专家 | 食品无尘净化车间,食品罐装净化车间,净化车间配套风淋室-青岛旭恒洁净技术有限公司 | 深圳湾1号房价_深圳湾1号二手房源| 上海刑事律师|刑事辩护律师|专业刑事犯罪辩护律师免费咨询-[尤辰荣]金牌上海刑事律师团队 | 机构创新组合设计实验台_液压实验台_气动实训台-戴育教仪厂 | 南京泽朗生物科技有限公司-液体饮料代加工_果汁饮料代加工_固体饮料代加工 | 振动时效_振动时效仪_超声波冲击设备-济南驰奥机电设备有限公司 北京宣传片拍摄_产品宣传片拍摄_宣传片制作公司-现像传媒 | 高温链条油|高温润滑脂|轴承润滑脂|机器人保养用油|干膜润滑剂-东莞卓越化学 | 充气膜专家-气膜馆-PTFE膜结构-ETFE膜结构-商业街膜结构-奥克金鼎 | 铝板冲孔网,不锈钢冲孔网,圆孔冲孔网板,鳄鱼嘴-鱼眼防滑板,盾构走道板-江拓数控冲孔网厂-河北江拓丝网有限公司 | 深圳昂为官网-气体分析仪,沼气分析仪,动态配气仪,气体传感器厂家 | 氧化锆陶瓷_氧化锆陶瓷加工_氧化锆陶瓷生产厂家-康柏工业陶瓷有限公司 | bkzzy在职研究生网 - 在职研究生招生信息咨询平台 | 高空重型升降平台_高空液压举升平台_高空作业平台_移动式升降机-河南华鹰机械设备有限公司 | 在线浊度仪_悬浮物污泥浓度计_超声波泥位计_污泥界面仪_泥水界面仪-无锡蓝拓仪表科技有限公司 | Q361F全焊接球阀,200X减压稳压阀,ZJHP气动单座调节阀-上海戎钛 | 深圳成考网-深圳成人高考报名网 深圳工程师职称评定条件及流程_深圳职称评审_职称评审-职称网 | 轴流风机-鼓风机-离心风机-散热风扇-罩极电机,生产厂家-首肯电子 | 电机保护器-电动机综合保护器-上海硕吉电器有限公司 | 慈溪麦田广告公司,提供慈溪广告设计。| 金属切削液-脱水防锈油-电火花机油-抗磨液压油-深圳市雨辰宏业科技发展有限公司 | 河南不锈钢水箱_地埋水箱_镀锌板水箱_消防水箱厂家-河南联固供水设备有限公司 | 冷藏车厂家|冷藏车价格|小型冷藏车|散装饲料车厂家|程力专用汽车股份有限公司销售十二分公司 | 【铜排折弯机,钢丝折弯成型机,汽车发泡钢丝折弯机,线材折弯机厂家,线材成型机,铁线折弯机】贝朗折弯机厂家_东莞市贝朗自动化设备有限公司 |