记一次if else 日常开发的简单优化写法

1、原代码
    if (index === 0) {
      dispatch({
        type: 'emailApi/inquireEmailReceiveListByPageAccount',
        payload: {
          loading: true,
        },
      });
      this.generateBadge();
    } else if (index === 1) {
      dispatch({
        type: 'emailApi/inquireEmailSendListByPageAccount',
        payload: {
          loading: true,
        },
      });
    } else if (index === 2) {
      dispatch({
        type: 'emailApi/inquireEmailDraftListByPageAccount',
        payload: {
          loading: true,
        },
      });
    } else {
      dispatch({
        type: 'emailApi/inquireEmailRecoverListByPageAccount',
        payload: {
          loading: true,
        },
      });
    }
在一开始书写这段代码的时候,就是单纯的if else 条件判断,后面开发完返过来看的时候,觉得非常的冗余,所以进行了以下更改。

2、简单改写后

借助数组索引取值,避免了冗余的if判断,将函数独立出来
    const typeList = [
      'inquireEmailReceiveListByPageAccount',
      'inquireEmailSendListByPageAccount',
      'inquireEmailDraftListByPageAccount',
      'inquireEmailRecoverListByPageAccount',
    ];
    dispatch({
      type: `emailApi/${typeList[index]}`,
      payload: {
        loading: true,
      },
    });

    if (index === 0) this.generateBadge();

这里要注意的是,我这样写的目的只是为了优化代码的结构,对于性能方面没有深入去研究,但是我相信这样改写之后性能一定有所提升。对于改写之后的代码可读性来说,我觉得不影响阅读。

也看到一些地方会使用三目运算符去改写if else判断,对于这种方式,我引用一段历史书上提到的观点。

少用三目运算符

有一些程序员喜欢大规模地使用三目运算符,来代替传统的 ifelse。理由是三目运算符性
能高,代码量少。不过,这两个理由其实都很难站得住脚。
即使我们假设三目运算符的效率真的比 ifelse 高,这点差距也是完全可以忽略不计的。

在实际的开发中,即使把一段代码循环一百万次,使用三目运算符和使用 ifelse 的时间开销
处在同一个级别里。
同样,相比损失的代码可读性和可维护性,三目运算符节省的代码量也可以忽略不计。让 JS
文件加载更快的办法有很多种,如压缩、缓存、使用 CDN 和分域名等。把注意力只放在使用三
目运算符节省的字符数量上,无异于一个 300 斤重的人把超重的原因归罪于头皮屑。 
如果条件分支逻辑简单且清晰,这无碍我们使用三目运算符:
var global = typeof window !== "undefined" ? window : this; 
但如果条件分支逻辑非常复杂,如下段代码所示,那我们最好的选择还是按部就班地编写
ifelseifelse 语句的好处很多,一是阅读相对容易,二是修改的时候比修改三目运算符周
围的代码更加方便: 
if ( !aup || !bup ) { 
 return a === doc ? -1 : 
 b === doc ? 1 : 
 aup ? -1 : 
 bup ? 1 : 
 sortInput ? 
 ( indexOf.call( sortInput, a ) - indexOf.call( sortInput, b ) ) : 
 0; 
}
总之,在优化代码的同时还要注意代码的可读性

在这里插入图片描述

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值