目录
一、策略模式的定义和特点
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大模型学习资源包》免费分享