news 2026/6/3 14:48:24

设计模式之-策略模式

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
设计模式之-策略模式

策略模式定义:

策略模式定义了一系列的算法,并且会将每一个算法封装起来,让它们可以相互的替换。

策略模式的组成:

一个基于策略模式的程序至少由两部分组成,第一部分是一组策略类,策略类封装了具体的算法,并负责具体计算过程,第二个部分是环境类Context,Context接受客户的请求,随后把请求委托给某一个策略类,说明Context中要维护对某个策略对象的引用

// 策略接口interfaceIStrategy{execute(a:number,b:number):number;}// 定义具体的策略类// 这里定义了四个具体的策略类,分别是加法、减法、乘法和除法classAddStrategyimplementsIStrategy{execute(a:number,b:number):number{returna+b;}}classSubStrategyimplementsIStrategy{execute(a:number,b:number):number{returna-b;}}classMulStrategyimplementsIStrategy{execute(a:number,b:number):number{returna*b;}}classDivStrategyimplementsIStrategy{execute(a:number,b:number):number{returna/b;}}// 上下文内部维护了具体的策略的引用// 回头客户端调用的时候,只需要调用上下文的方法即可classContext{// 维护具体的策略privatestrategy:IStrategy;constructor(st:IStrategy){this.strategy=st;}// 设置新的策略setStrategy(st:IStrategy){this.strategy=st;}//执行策略方法executeStrategy(a:number,b:number):number{returnthis.strategy.execute(a,b);}}// 创建一个上下文对象// 在创建的时候,传递一个默认的执行策略constcontext=newContext(newAddStrategy());// 执行对应的策略consta=5;constb=3;constresult=context.executeStrategy(a,b);context.setStrategy(newSubStrategy())constresult2=context.executeStrategy(a,b);context.setStrategy(newMulStrategy());constresult3=context.executeStrategy(a,b);console.log(result);console.log(result2);console.log(result3);

再来看一个表单的例子

<formid="registerForm"action="#">请输入用户名:<inputtype="text"name="username"/>请输入密码:<inputtype="text"name="password"/>请输入手机号:<inputtype="text"name="phoneNumber"/><buttonid="button">提交</button></form><script>varregisterForm=document.getElementById('registerForm');varbutton=document.getElementById('button');button.onclick=function(){if(registerForm.username.value===''){console.log('用户名不能为空');returnfalse}if(registerForm.password.value.length<6){console.log('密码长度不能少于6位');returnfalse}if(!/(^1[3|5|8][0-9]{9}$)/.test(registerForm.phoneNumber.value)){console.log('手机号码格式不正确');returnfalse}}</script>

这是一种很常见的做法,提交函数比较庞大,缺少弹性,违反开放-封闭原则
下面用策略模式来重构表单校验

varstrategies={isNonEmpty:function(value,errorMsg){// 不为空if(value===''){returnerrorMsg;}},minLength:function(value,length,errorMsg){// 限制最小长度if(value.length<length){returnerrorMsg;}},isMobile:function(value,errorMsg){// 手机号码格式if(!/(^1[3|5|8][0-9]{9}$)/.test(value)){returnerrorMsg;}}}varvalidataFunc=function(){varvalidator=newValidator();// 创建一个validator对象// 添加一些校验规则validator.add(registerForm.username,'isNonEmpty','用户名不能为空');validator.add(registerForm.password,'minLength:6','密码长度不能少于6位');validator.add(registerForm.phoneNumber,'isMobile','手机号码格式不正确');varerrorMsg=validator.start();// 获得校验结果returnerrorMsg;// 返回校验结果}varregisterForm=document.getElementById('registerForm');varbutton=document.getElementById('button');button.onclick=function(e){e.preventDefault();varerrorMsg=validataFunc();// 如果有返回值,说明未通过校验if(errorMsg){console.log(errorMsg);returnfalse;}}varValidator=function(){this.cache=[];// 保存校验规则}Validator.prototype.add=function(dom,rule,erroeMsg){vararg=rule.split(':');// 把strategy和参数分开this.cache.push(function(){// 把校验的步骤用空函数包装起来,并且放入cachevarstrategy=arg.shift();// 用户挑选的strategyarg.unshift(dom.value);arg.push(erroeMsg);returnstrategies[strategy].apply(dom,arg);})}Validator.prototype.start=function(){for(leti=0,validataFunc;validataFunc=this.cache[i++];){varmsg=validataFunc();// 开始校验,并取得校验后返回信息if(msg){// 有返回值,说明校验没有通过returnmsg;}}}

非原创,来源渡一谢杰老师和javascript设计模式与开发实践 -曾探 简单记录,周五啦,周末愉快

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/1 2:35:21

【DC-AC】使用了H桥MOSFET进行开关,电感器作为滤波器,R和C作为负载目标是产生150V的双极输出和4安培(双极)的电流simulink实现

✅作者简介&#xff1a;热爱科研的Matlab仿真开发者&#xff0c;擅长数据处理、建模仿真、程序设计、完整代码获取、论文复现及科研仿真。&#x1f34e; 往期回顾关注个人主页&#xff1a;Matlab科研工作室&#x1f34a;个人信条&#xff1a;格物致知,完整Matlab代码及仿真咨询…

作者头像 李华
网站建设 2026/6/2 13:17:32

智慧校园招投标时间管理的核心节点把控

✅作者简介&#xff1a;合肥自友科技 &#x1f4cc;核心产品&#xff1a;智慧校园平台(包括教工管理、学工管理、教务管理、考务管理、后勤管理、德育管理、资产管理、公寓管理、实习管理、就业管理、离校管理、科研平台、档案管理、学生平台等26个子平台) 。公司所有人员均有多…

作者头像 李华
网站建设 2026/5/26 1:37:25

FaceFusion开源社区活跃度报告:开发者生态正在崛起

FaceFusion开源社区活跃度报告&#xff1a;开发者生态正在崛起在AIGC浪潮席卷全球的今天&#xff0c;图像生成与视觉编辑技术正以前所未有的速度渗透进创作、娱乐乃至工业领域。其中&#xff0c;人脸替换&#xff08;Face Swapping&#xff09;作为最具争议也最引人注目的方向之…

作者头像 李华
网站建设 2026/6/2 14:40:25

为啥要有枚举这个类型,定义一个类,其中定义常量不就行了

枚举类型 vs 常量类 1. 类型安全性 // 使用枚举 - 编译时类型检查 public enum Status {ACTIVE, INACTIVE } void processStatus(Status status) { }// 调用时只能传入定义的枚举值 processStatus(Status.ACTIVE); // ✓ 正确 processStatus("ACTIVE"); // ✗ 编译错…

作者头像 李华
网站建设 2026/5/31 23:15:53

Langchain-Chatchat如何集成快捷键操作?效率提升技巧

Langchain-Chatchat如何集成快捷键操作&#xff1f;效率提升技巧 在企业级知识管理系统中&#xff0c;一个看似微不足道的交互细节——比如是否支持“Ctrl Enter 发送消息”——往往决定了用户是愿意每天使用它&#xff0c;还是用一次就弃之不用。随着本地大模型部署方案逐渐…

作者头像 李华
网站建设 2026/5/27 22:15:13

利用Langchain-Chatchat降低企业AI应用的数据泄露风险

利用Langchain-Chatchat降低企业AI应用的数据泄露风险 在金融、医疗和法律等行业&#xff0c;一份合同、一条病历或一纸合规文件的外泄&#xff0c;都可能引发连锁反应——监管处罚、客户流失、品牌声誉受损。而当这些敏感信息需要接入AI系统以实现智能问答时&#xff0c;传统基…

作者头像 李华