#每日一记# 用策略模式替代 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 分钟前
前端数据加密:保护用户数据的第一道防线
前端
running up7 分钟前
Java集合框架之ArrayList与LinkedList详解
javascript·ubuntu·typescript
纪伊路上盛名在10 分钟前
记1次BioPython Entrez模块Elink的debug
前端·数据库·python·debug·工具开发
xiaoxue..12 分钟前
React 之 Hooks
前端·javascript·react.js·面试·前端框架
Alair‎16 分钟前
300TypeScript基础知识
javascript
旧梦吟17 分钟前
脚本网页 三人四字棋
前端·数据库·算法·css3·html5
莫物19 分钟前
element el-table表格 添加唯一标识
前端·javascript·vue.js
我看刑20 分钟前
【已解决】el-table 前端分页多选、跨页全选等
前端·vue·element
我会一直在的26 分钟前
Fiddler基础使用介绍
前端·测试工具·fiddler
小明记账簿26 分钟前
前端文件流下载方法封装
前端