#每日一记# 用策略模式替代 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}`]
}

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

相关推荐
J***Q2928 小时前
Vue数据可视化
前端·vue.js·信息可视化
ttod_qzstudio10 小时前
深入理解 Vue 3 的 h 函数:构建动态 UI 的利器
前端·vue.js
芳草萋萋鹦鹉洲哦10 小时前
【elemen/js】阻塞UI线程导致的开关卡顿如何优化
开发语言·javascript·ui
_大龄10 小时前
前端解析excel
前端·excel
1***s63210 小时前
Vue图像处理开发
javascript·vue.js·ecmascript
槁***耿11 小时前
JavaScript在Node.js中的事件发射器
开发语言·javascript·node.js
一叶茶11 小时前
移动端平板打开的三种模式。
前端·javascript
前端大卫11 小时前
一文搞懂 Webpack 分包:async、initial 与 all 的区别【附源码】
前端
U***498311 小时前
JavaScript在Node.js中的Strapi
开发语言·javascript·node.js
Want59511 小时前
HTML音乐圣诞树
前端·html