前端策略模式

  • 策略模式:
  1. 一种常用且有效的设计模式
  2. 策略(Strategy)模式定义了一系列算法,并将每个算法封装起来,使它们可以相互替换,策略模式的目的就是将算法的使用与算法的实现分离开来,算法的变化不会影响使用算法的客户。

  3. 策略模式属于对象行为模式,它通过对算法进行封装,把使用算法的责任和算法的实现分割开来,并委派给不同的对象对这些算法进行管理。

  4. 策略(Strategy)模式最核心的一点就是,每个算法的结构是一样的,体现在 js 中,可能就是入参和返回值一样,这样才能保证可以相互替换。

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

  • 策略模式优点:

  1. 策略模式利用组合、委托和多态等技术和思想,可以有效地避免多重条件选择语句。

  2. 策略模式将算法封装在独立的 strategy 中,使得它们易于切换,易于理解,易于扩展。

  3. 策略模式中的算法也可以复用在系统的其他地方,从而避免许多重复的复制粘贴工作。

  4. 在策略模式中利用组合和委托来让 Context 拥有执行算法的能力,这也是继承的一种更轻便的替代方案。

  • 策略模式缺点:

  1. 策略模式的缺点并不严重

  2. 使用策略模式会在程序中增加许多策略类或者策略对象,但实际上这比把它们负责的

    逻辑堆砌在 Context 中要好。

  3. 要使用策略模式,必须了解所有的 strategy(策略),必须了解各个 strategy 之间的不同点,这样才能选择一个合适的 strategy

 

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

慷首滇洛帼

你的鼓励将是我创作的最大动力

¥2 ¥4 ¥6 ¥10 ¥20
输入1-500的整数
余额支付 (余额:-- )
扫码支付
扫码支付:¥2
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值