关于策略模式我所知道的

简介: 关于策略模式我所知道的

image.png


本文已参与「新人创作礼」活动,一起开启掘金创作之路。

关键词:行为型 组织organize 分发dispatch

先让我们来看一段简单的代码,来初步了解下什么是策略模式:


image.png

使用策略模式的目的


从代码中我们可以看出,使用策略模式可以移除大量需要 if-else 或者 switch-case 分支判断的代码。

这就是我们使用策略模式的主要目的:

  1. 将业务逻辑拆分(解耦),控制代码的复杂度。
  2. 添加新策略的时候,可以最小化改动。只要新增一个策略就可以解决问题。


什么是策略模式


策略模式,英文全称是 Strategy Design Pattern。在 GoF 的《设计模式》一书中,它是这样定义的

定义一组策略类,将每个策略分别封装起来,让它们可以互相替换。

结合自己在开发中的使用体验,我是这么理解的:

策略模式分两部分构成

  1. 一组封装好的方法/类
  2. 使方法/类可以相互替换,实现变更策略。


如何实现策略模式

1. 一组封装好的方法/类


interface Strategy {
  doAlgorithm(data: string[]): string[];
}
// 策略A
class ConcreteStrategyA implements Strategy {
  public doAlgorithm(data: string[]): string[] {
    return data.sort();
  }
}
// 策略B
class ConcreteStrategyB implements Strategy {
  public doAlgorithm(data: string[]): string[] {
    return data.reverse();
  }
}

2. 使方法/类相互替换,实现变更策略。


现在我们有了一组策略,还需要判断应该使用哪个策略。这就又需要新增一个类去解决这个问题。


// 一组策略的代码 
// 执行策略的工厂类
class Context {
  private strategy: Strategy;
  constructor(strategy: Strategy) {
    this.strategy = strategy;
  }
  // 设置/切换策略
  public setStrategy(strategy: Strategy) {
    this.strategy = strategy;
  }
  // 执行相应的策略逻辑
  public doSomeBusinessLogic(arr: string[]): void {
    const result = this.strategy.doAlgorithm(arr);
    console.log(result.join(","));
  }
}
// 测试代码
const arr: string[] = ["a", "b", "c", "d", "e"];
const context = new Context(new ConcreteStrategyA());
context.doSomeBusinessLogic(arr); // a,b,c,d,e
context.setStrategy(new ConcreteStrategyB());
context.doSomeBusinessLogic(arr); // e,d,c,b,a

策略模式可以说是前端用的比较多的设计模式,通过使用策略模式可以书写出让程序结构更灵活、可维护、可拓展的代码。

实现也非常简单,重点不在于如何实现方法,而是如何组织调用这些方法。


应用场景


  1. 表单校验

image.png

  1. 按钮组

上面的代码

  1. 多种登录方式


interface Strategy {
  authenticate(...args: any): any;
}
class Authenticator {
  private strategy: Strategy;
  constructor(strategy: Strategy) {
    this.strategy = strategy;
  }
  // 设置/切换策略
  public setStrategy(strategy: Strategy) {
    this.strategy = strategy;
  }
  // 执行相应的策略逻辑
  public authenticate(...args: any): any {
    if (!this.strategy) {
      console.log('尚未设置认证策略');
      return;
    }
    return this.strategy.authenticate(...args);
  }
}
class WechatStrategy implements Strategy {
  authenticate(wechatToken: string) {
    if (wechatToken !== 'xxx') {
      console.log('无效的微信用户');
      return;
    }
    console.log('微信认证成功');
  }
}
class LocalStrategy implements Strategy {
  authenticate(username: string, password: string) {
    if (username !== 'xxx' && password !== 'xxx') {
      console.log('账号或密码错误');
      return;
    }
    console.log('账号和密码认证成功');
  }
}
const auth = new Authenticator(new WechatStrategy());
auth.authenticate('xxx');
auth.setStrategy(new LocalStrategy());
auth.authenticate('xxx', 'xxx');
目录
相关文章
|
2月前
|
设计模式 算法 搜索推荐
策略模式的小记
本文介绍了策略模式的概念、结构和使用场景,并通过支付系统的例子展示了如何使用策略模式来动态选择不同的支付策略,包括定义支付策略接口、实现具体的支付策略类、创建上下文类以及在客户端动态选择支付策略。
策略模式的小记
|
6月前
|
算法 数据安全/隐私保护
行为型 策略模式
行为型 策略模式
34 1
|
设计模式 算法 Java
什么场景要使用策略模式,什么场景不能使用?
如果,让我来设计,我最先想到的就是策略模式。另外,我把往期面试题解析的配套文档我已经准备好,想获得的可以在我的煮叶简介中找到。那么什么场景要使用策略模式,什么场景又不应该使用策略模式呢?我们可以先来看官方对策略模式的定义。
164 0
|
前端开发
策略模式
策略模式
78 0
|
设计模式 算法
策略模式详细介绍
策略模式(Strategy Pattern)是一种行为型设计模式,它定义了一系列的算法,并将每个算法封装到具有共同接口的独立类中,使得它们可以互相替换。策略模式可以让算法的变化独立于使用它的客户端。
122 0
|
算法 测试技术 C#
C#策略模式
C#策略模式
70 0
|
算法 程序员 开发工具
简单说说我对策略模式的了解
简单说说我对策略模式的了解
87 0
|
设计模式 算法
我学会了,策略模式
策略模式属于行为型模式,这个类型的设计模式总结出了 类、对象之间的经典交互方式,将类、对象的行为和使用解耦了,花式的去使用对象的行为来完成特定场景下的功能。
123 0
我学会了,策略模式