news 2026/4/20 17:14:31

前端开发设计模式——策略模式,零基础入门到精通,收藏这篇就够了

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
前端开发设计模式——策略模式,零基础入门到精通,收藏这篇就够了

目录

一、策略模式的定义和特点

1.定义:

2.特点:

二、策略模式的实现方式

1.定义策略接口:

2.创建具体策略类:

3.定义上下文类:

三、策略模式的应用场景

1.表单验证场景:

2.动画效果切换场景:

3.数据处理和格式化场景:

四、策略模式的优点

1.可维护性:

2.可扩展性:

3.灵活性:

五、策略模式的缺点

1.增加代码复杂度:

2.性能开销:

六、策略模式的注意事项

1.策略命名规范:

2.策略的选择逻辑:

3.策略的可测试性:


一、策略模式的定义和特点

1.定义:
策略模式是一种行为设计模式,它定义了一系列的算法,并将每个算法封装起来,使它们可以相互替换。在前端开发中,策略模式允许根据不同的情况动态地选择和应用不同的算法或行为,而无需修改使用这些算法的主体代码。
2.特点:
**算法封装:**将不同的算法封装在独立的策略类中,每个策略类实现特定的行为逻辑。 **可替换性:**不同的策略可以在运行时相互替换,使得系统更加灵活。 **解耦性:**策略模式将算法的实现与使用算法的主体代码解耦,提高了代码的可维护性和可扩展性。

二、策略模式的实现方式

1.定义策略接口:
首先,定义一个策略接口,该接口声明了所有具体策略类必须实现的方法。例如:
interface Strategy { execute(): void; }
2.创建具体策略类:
实现具体的策略类,每个策略类实现策略接口中的方法,并提供特定的算法实现。例如:
class ConcreteStrategyA implements Strategy { execute() { console.log('Executing strategy A.'); } } class ConcreteStrategyB implements Strategy { execute() { console.log('Executing strategy B.'); } }
3.定义上下文类:
上下文类持有一个策略对象的引用,并通过该引用调用策略对象的方法。上下文类可以在运行时设置不同的策略对象。例如:
class Context { private strategy: Strategy; constructor(strategy: Strategy) { this.strategy = strategy; } setStrategy(strategy: Strategy) { this.strategy = strategy; } executeStrategy() { this.strategy.execute(); } }

三、策略模式的应用场景

1.表单验证场景:
根据不同的表单字段类型和需求,可以使用不同的验证策略。例如,对于电子邮件字段,可以使用一个验证电子邮件格式的策略;对于密码字段,可以使用一个验证密码强度的策略. **示例:** (1)定义策略接口:
interface ValidationStrategy { validate(value): boolean; }
(2)创建具体策略类: 邮箱验证策略:
class EmailValidationStrategy implements ValidationStrategy { validate(value) { const emailRegex = /^[^\s@]+@[^\s@]+\.[^\s@]+$/; return emailRegex.test(value); } }
密码长度验证策略:
class PasswordLengthValidationStrategy implements ValidationStrategy { validate(value) { return value.length >= 8; } }
(3)定义上下文类(表单组件):
class FormComponent { private validationStrategy: ValidationStrategy; constructor(strategy: ValidationStrategy) { this.validationStrategy = strategy; } setValidationStrategy(strategy: ValidationStrategy) { this.validationStrategy = strategy; } validateInput(value) { return this.validationStrategy.validate(value); } }
(4)使用示例:
// 使用邮箱验证策略 const emailFormComponent = new FormComponent(new EmailValidationStrategy()); const isEmailValid = emailFormComponent.validateInput('test@example.com'); console.log('Email is valid:', isEmailValid); // 切换为密码长度验证策略 emailFormComponent.setValidationStrategy(new PasswordLengthValidationStrategy()); const isPasswordValid = emailFormComponent.validateInput('12345678'); console.log('Password is valid:', isPasswordValid);
2.动画效果切换场景:
在前端动画中,可以根据不同的场景和用户交互选择不同的动画效果策略。例如,在页面加载时可以使用一种淡入效果,在用户点击按钮时可以使用一种弹出效果。 **示例:** (1)定义策略接口:
interface AnimationStrategy { animate(element): void; }
(2)创建具体策略类: 淡入动画策略:
class FadeInAnimationStrategy implements AnimationStrategy { animate(element) { element.style.opacity = '0'; let opacity = 0; const interval = setInterval(() => { opacity += 0.1; element.style.opacity = opacity.toString(); if (opacity >= 1) { clearInterval(interval); } }, 100); } }
弹出动画策略:
class PopupAnimationStrategy implements AnimationStrategy { animate(element) { element.style.transform = 'scale(0)'; let scale = 0; const interval = setInterval(() => { scale += 0.1; element.style.transform = `scale(${scale})`; if (scale >= 1) { clearInterval(interval); } }, 100); } }
(3)定义上下文类(动画控制器):
class AnimationController { private animationStrategy: AnimationStrategy; constructor(strategy: AnimationStrategy) { this.animationStrategy = strategy; } setAnimationStrategy(strategy: AnimationStrategy) { this.animationStrategy = strategy; } startAnimation(element) { this.animationStrategy.animate(element); } }
(4)使用示例:
// 使用淡入动画策略 const fadeInController = new AnimationController(new FadeInAnimationStrategy()); const elementToAnimate = document.createElement('div'); document.body.appendChild(elementToAnimate); fadeInController.startAnimation(elementToAnimate); // 切换为弹出动画策略 fadeInController.setAnimationStrategy(new PopupAnimationStrategy()); const anotherElementToAnimate = document.createElement('div'); document.body.appendChild(anotherElementToAnimate); fadeInController.startAnimation(anotherElementToAnimate);
3.数据处理和格式化场景:
对于不同类型的数据,可以使用不同的数据处理和格式化策略。例如,对于日期数据,可以使用不同的日期格式化策略;对于数字数据,可以使用不同的数字格式化策略。 这个就不举例了......

四、策略模式的优点

1.可维护性:
将不同的算法封装在独立的策略类中,使得代码更加清晰、易于维护。当需要修改某个算法时,只需修改相应的策略类,而不会影响其他部分的代码。
2.可扩展性:
可以方便地添加新的策略类,实现新的算法或行为,而无需修改现有的代码。这使得系统具有良好的可扩展性。
3.灵活性:
策略模式允许在运行时根据不同的情况选择不同的策略,使得系统更加灵活。可以根据用户的输入、系统状态或其他条件动态地切换策略。

五、策略模式的缺点

1.增加代码复杂度:
引入策略模式会增加代码的复杂度,特别是当有多个策略类时。需要更多的类和接口,以及更多的代码来管理策略的选择和切换。
2.性能开销:
在运行时动态地选择策略可能会带来一定的性能开销。特别是当策略的选择和切换比较频繁时,可能会影响系统的性能。

六、策略模式的注意事项

1.策略命名规范:
为了提高代码的可读性和可维护性,应该为策略类和方法使用清晰、有意义的命名规范。这样可以更容易地理解每个策略的作用和用途。
2.策略的选择逻辑:
在上下文类中,应该有明确的逻辑来选择合适的策略。可以根据用户的输入、系统状态或其他条件来选择策略。同时,应该考虑策略的优先级和适用性,以确保选择的策略是最合适的。
3.策略的可测试性:
由于策略模式将算法的实现与使用算法的主体代码解耦,因此策略类通常比较容易进行单元测试。可以为每个策略类编写独立的测试用例,确保它们的行为符合预期。同时,也应该测试上下文类对策略的选择和切换逻辑。 对于前端开发设计模式中的策略模式就分享到这,如果对设计模式中的其他模式有兴趣的话,可以点开主页看看相关文章。码字不易,点个赞再走吧

2025开年,AI技术打得火热,正在改变前端人的职业命运:

阿里云核心业务全部接入Agent体系;

字节跳动30%前端岗位要求大模型开发能力;

腾讯、京东、百度开放招聘技术岗,80%与AI相关……

大模型正在重构技术开发范式,传统CRUD开发模式正在被AI原生应用取代!

最残忍的是,业务面临转型,领导要求用RAG优化知识库检索,你不会;带AI团队,微调大模型要准备多少数据,你不懂;想转型大模型应用开发工程师等相关岗,没项目实操经验……这不是技术焦虑,而是职业生存危机!

曾经React、Vue等热门的开发框架,已不再是就业的金钥匙。如果认为会调用API就是懂大模型、能进行二次开发,那就大错特错了。制造、医疗、金融等各行业都在加速AI应用落地,未来企业更看重能用AI大模型技术重构业务流的技术人。

如今技术圈降薪裁员频频爆发,传统岗位大批缩水,相反AI相关技术岗疯狂扩招,薪资逆势上涨150%,大厂老板们甚至开出70-100W年薪,挖掘AI大模型人才!

不出1年 “有AI项目开发经验”或将成为前端人投递简历的门槛。

风口之下,与其像“温水煮青蛙”一样坐等被行业淘汰,不如先人一步,掌握AI大模型原理+应用技术+项目实操经验,“顺风”翻盘!

大模型目前在人工智能领域可以说正处于一种“炙手可热”的状态,吸引了很多人的关注和兴趣,也有很多新人小白想要学习入门大模型,那么,如何入门大模型呢?

下面给大家分享一份2025最新版的大模型学习路线,帮助新人小白更系统、更快速的学习大模型!

2025最新版CSDN大礼包:《AGI大模型学习资源包》免费分享**

一、2025最新大模型学习路线

一个明确的学习路线可以帮助新人了解从哪里开始,按照什么顺序学习,以及需要掌握哪些知识点。大模型领域涉及的知识点非常广泛,没有明确的学习路线可能会导致新人感到迷茫,不知道应该专注于哪些内容。

我们把学习路线分成L1到L4四个阶段,一步步带你从入门到进阶,从理论到实战。

L1级别:AI大模型时代的华丽登场

L1阶段:我们会去了解大模型的基础知识,以及大模型在各个行业的应用和分析;学习理解大模型的核心原理,关键技术,以及大模型应用场景;通过理论原理结合多个项目实战,从提示工程基础到提示工程进阶,掌握Prompt提示工程。

L2级别:AI大模型RAG应用开发工程

L2阶段是我们的AI大模型RAG应用开发工程,我们会去学习RAG检索增强生成:包括Naive RAG、Advanced-RAG以及RAG性能评估,还有GraphRAG在内的多个RAG热门项目的分析。

L3级别:大模型Agent应用架构进阶实践

L3阶段:大模型Agent应用架构进阶实现,我们会去学习LangChain、 LIamaIndex框架,也会学习到AutoGPT、 MetaGPT等多Agent系统,打造我们自己的Agent智能体;同时还可以学习到包括Coze、Dify在内的可视化工具的使用。

L4级别:大模型微调与私有化部署

L4阶段:大模型的微调和私有化部署,我们会更加深入的探讨Transformer架构,学习大模型的微调技术,利用DeepSpeed、Lamam Factory等工具快速进行模型微调;并通过Ollama、vLLM等推理部署框架,实现模型的快速部署。

整个大模型学习路线L1主要是对大模型的理论基础、生态以及提示词他的一个学习掌握;而L3 L4更多的是通过项目实战来掌握大模型的应用开发,针对以上大模型的学习路线我们也整理了对应的学习视频教程,和配套的学习资料。

二、大模型经典PDF书籍

书籍和学习文档资料是学习大模型过程中必不可少的,我们精选了一系列深入探讨大模型技术的书籍和学习文档,它们由领域内的顶尖专家撰写,内容全面、深入、详尽,为你学习大模型提供坚实的理论基础(书籍含电子版PDF)

三、大模型视频教程

对于很多自学或者没有基础的同学来说,书籍这些纯文字类的学习教材会觉得比较晦涩难以理解,因此,我们提供了丰富的大模型视频教程,以动态、形象的方式展示技术概念,帮助你更快、更轻松地掌握核心知识

四、大模型项目实战

学以致用,当你的理论知识积累到一定程度,就需要通过项目实战,在实际操作中检验和巩固你所学到的知识,同时为你找工作和职业发展打下坚实的基础。

五、大模型面试题

面试不仅是技术的较量,更需要充分的准备。

在你已经掌握了大模型技术之后,就需要开始准备面试,我们将提供精心整理的大模型面试题库,涵盖当前面试中可能遇到的各种技术问题,让你在面试中游刃有余。


因篇幅有限,仅展示部分资料,需要点击下方链接即可前往获取

2025最新版CSDN大礼包:《AGI大模型学习资源包》免费分享

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

当科学幻想照进现实:虎贲等考AI科研绘图,重新定义研究的视觉语言

当键盘敲下第一个字,屏幕另一端的人工智能几乎同步生成着相似的内容。在这个AIGC井喷的时代,人类作者的“文字指纹”正在经历前所未有的身份危机——我们的表达,还能在多大程度上保持独特性?一、数字时代的表达困境:当…

作者头像 李华
网站建设 2026/4/17 21:00:09

AutoGLM-Phone-9B模型实测:性能媲美云端服务?本地推理全流程解析

第一章:AutoGLM-Phone-9B模型实测:性能媲美云端服务?随着边缘计算能力的提升,将大语言模型部署至移动设备已成为可能。AutoGLM-Phone-9B作为专为终端侧优化的90亿参数模型,其在本地运行的表现引发了广泛关注。本章通过…

作者头像 李华
网站建设 2026/4/19 19:38:26

深色模式编程字体优化终极指南:Hasklig深度解析与实战技巧

深色模式编程字体优化终极指南:Hasklig深度解析与实战技巧 【免费下载链接】Hasklig Hasklig - a code font with monospaced ligatures 项目地址: https://gitcode.com/gh_mirrors/ha/Hasklig 现象分析:深色模式下的字体显示挑战 在当今编程环境…

作者头像 李华
网站建设 2026/4/18 12:46:15

测试工程师的数据隐私保护之道

在数字化转型加速的2025年,数据隐私保护已成为软件测试领域不可回避的核心议题。随着《个人信息保护法》等法规的深入实施,测试从业者面临着双重挑战:既要确保软件质量,又要守护用户数据安全。本文旨在为测试工程师提供一套切实可…

作者头像 李华
网站建设 2026/4/20 19:34:14

基于Django的视频论坛系统的设计与实现(源码+lw+远程部署)

目录: 博主介绍: 完整视频演示: 系统技术介绍: 后端Java介绍 前端框架Vue介绍 具体功能截图: 部分代码参考: Mysql表设计参考: 项目测试: 项目论文:​ 为…

作者头像 李华
网站建设 2026/4/19 9:48:27

FaceFusion在心理治疗中的辅助作用研究设想

FaceFusion在心理治疗中的辅助作用研究设想 在临床心理干预实践中,一个长期存在的难题是:许多患者——尤其是儿童、创伤幸存者或社交障碍个体——难以通过语言准确表达内在情绪与自我认知。传统的谈话疗法依赖于言语叙述,但当一个人连“我是谁…

作者头像 李华