#每日一记# 用策略模式替代 if…else 写出更优雅的代码

我个人理解的策略模式就是把原本 if...else 中的条件判断存到一个对象的 key 上,让原本命令式代码转变为申明式。极大的增加了代码灵活性和可读性。

这个写法用的好,代码可以写的赏心悦目。

基本用法

场景:不同的任务类型分配不同的奖池

javascript 复制代码
function getRewards (taskType) {
  if (taskType === 1) {
    return ['手机', '电脑', '平板']
  }
  else if (taskType === 2) {
    return ['水杯', '笔记本']
  }
}
javascript 复制代码
function getRewards (taskType) {
  const rewardMap = {
    1: ['手机', '电脑', '平板'],
    2: ['水杯', '笔记本'],
  }

  return rewardMap[taskType]
}

本质上是一种形式的规范,从过于灵活的形式变化为整齐有规律的形式。

复杂用法

当条件比较复杂时,就可以有一些不同的花样可以玩。

场景:不同的年龄段分配不同的底薪

javascript 复制代码
function getBaseSalary (age) {
  const baseSalaryMap = {
    s1: {
      condition: (age) => age < 20,
      baseSalary: 1000,
    },
    s2: {
      condition: (age) => age >= 20 && age < 30,
      baseSalary: 2000,
    },
    s3: {
      condition: (age) => age >= 30,
      baseSalary: 3000,
    },
  }

  return (
    Object
    .values(baseSalaryMap)
    .find((item) => item.condition(age))
    .baseSalary
  )
}

场景:两个开关控制一个灯

javascript 复制代码
function getBaseSalary (switch1, switch2) {

  const resMap = {
    true_true: '1',
    true_false: '2',
    false_true: '3',
    false_false: '4',
  }

  return resMap[`${switch1}_${switch2}`]
}

还有什么更有趣的场景,评论区可以留言分享。

相关推荐
萑澈5 小时前
Windows 7 运行 Electron 安装包报“不是有效的 Win32 应用程序”怎么办
javascript·windows·electron
W.A委员会5 小时前
JS原型链详解
开发语言·javascript·原型模式
懂懂tty6 小时前
React状态更新流程
前端·react.js
小码哥_常6 小时前
告别繁琐!手把手教你封装超实用Android原生Adapter基类
前端
她说彩礼65万6 小时前
C# 实现简单的日志打印
开发语言·javascript·c#
skywalk81636 小时前
pytest测试的时候这是什么意思?Migrating <class ‘kotti.resources.File‘>
前端·python
一只蝉nahc7 小时前
vue使用iframe内嵌unity模型,并且向模型传递信息,接受信息
前端·vue.js·unity
状元岐7 小时前
C#反射从入门到精通
java·javascript·算法
子兮曰7 小时前
Bun v1.3.12 深度解析:新特性、性能优化与实战指南
前端·typescript·bun
2401_885885048 小时前
易语言彩信接口怎么调用?E语言Post实现多媒体数据批量下发
前端