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

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

相关推荐
英俊潇洒美少年18 小时前
Vue 生产环境打包:SourceMap、压缩、混淆、Gzip、多环境配置 企业级最佳实践
前端·javascript·vue.js
MXN_小南学前端18 小时前
Vue 后台管理系统:封装通用el-table导出方法(附完整源码)
javascript·vue.js
2601_9577867718 小时前
企业矩阵运营的“三段论“:管号、产内容、获线索——全链路系统的价值拆解
java·前端·矩阵·多平台管理
城市的稻草人VS18 小时前
rust【日志库】
前端·rust
问心无愧051318 小时前
ctf show web 入门258
android·前端·笔记
xwjalyf19 小时前
javascript数组 forEach,filter,some,every,map,find,reduce的用法与区别
开发语言·javascript·json·ecmascript
海兰19 小时前
【小程序】 贪吃蛇(Next.js+WebSocket+SQLite + Prisma ORM)
javascript·websocket·小程序
qq_25183645719 小时前
基于java Web 耗材购置与维修网络申报审批系统设计与实现
java·开发语言·前端
UXbot19 小时前
企业AI开发工具:界面自动生成与前端代码交付能力详解
前端·人工智能·交互·web app·ui设计
专业技术员!!!!19 小时前
陪玩系统前端核心功能详解|线上线下陪玩平台开发方案
前端·陪玩系统·电竞陪玩