使用Map代替switch或多个if

前端代码一定要优雅。

使用Map代替switch或多个if判断,是可避免代码复杂度过高的有效方法之一:

function getText(status) {
  switch (status) {
    case 1:
      return '试用客户';
    case 2:
      return '正式客户';
    case 3:
      return '签约客户';
    default:
      return '';
  }
}

// 使用Map替代
const textMap = new Map()
    .set(1, '试用客户')
    .set(2, '正式客户')
    .set(3, '签约客户');
// 或
const textMap = new Map([
  [1, '试用客户'],
  [2, '正式客户'],
  [3, '签约客户'],
]); 
const text = textMap.get(status);

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
引用\[1\]中提到,如果一个switch语句包含超过5个情况,它会使用lookup table或hash list来实现。这意味着所有的情况都会在同一时间内被访问,相比之下,使用一连串的if语句,最后一个if的情况总是要花更多的时间才能被访问,因为必须要优先比较之前的所有if情况。\[2\]因此,如果情况较多,使用switch语句可能会更快。然而,如果只有几个情况,switch语句的速度可能不会有太大影响,可以使用if-else语句。另外,引用\[3\]中提到,使用map中的key和value键值对来取代if-else语句也可以提高效率。通过将不同情况的函数与对应的key值关联起来,可以通过查找key值来执行相应的函数,避免了多个if-else语句的嵌套。这种方法在处理多个情况时可以更加高效。 #### 引用[.reference_title] - *1* *2* [if和switch效率比较](https://blog.csdn.net/qq_35719728/article/details/110931252)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [在C++中使用map来取代很多个if else和switch](https://blog.csdn.net/qq_41655797/article/details/124323500)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值