记一次if else 日常开发的简单优化写法
发布日期:2021-05-20 10:07:10
浏览次数:30
分类:技术文章
本文共 2015 字,大约阅读时间需要 6 分钟。
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判断,对于这种方式,我引用一段历史书上提到的观点。
少用三目运算符
有一些程序员喜欢大规模地使用三目运算符,来代替传统的 if、else。理由是三目运算符性能高,代码量少。不过,这两个理由其实都很难站得住脚。即使我们假设三目运算符的效率真的比 if、else 高,这点差距也是完全可以忽略不计的。在实际的开发中,即使把一段代码循环一百万次,使用三目运算符和使用 if、else 的时间开销处在同一个级别里。同样,相比损失的代码可读性和可维护性,三目运算符节省的代码量也可以忽略不计。让 JS文件加载更快的办法有很多种,如压缩、缓存、使用 CDN 和分域名等。把注意力只放在使用三目运算符节省的字符数量上,无异于一个 300 斤重的人把超重的原因归罪于头皮屑。 如果条件分支逻辑简单且清晰,这无碍我们使用三目运算符:var global = typeof window !== "undefined" ? window : this; 但如果条件分支逻辑非常复杂,如下段代码所示,那我们最好的选择还是按部就班地编写if、else。if、else 语句的好处很多,一是阅读相对容易,二是修改的时候比修改三目运算符周围的代码更加方便: if ( !aup || !bup ) { return a === doc ? -1 : b === doc ? 1 : aup ? -1 : bup ? 1 : sortInput ? ( indexOf.call( sortInput, a ) - indexOf.call( sortInput, b ) ) : 0; }
总之,在优化代码的同时还要注意代码的可读性
转载地址:https://blog.csdn.net/weixin_45416217/article/details/115959486 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!
发表评论
最新留言
关注你微信了!
[***.104.42.241]2024年03月31日 02时36分16秒
关于作者
喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
【Android平台】 Alljoyn学习笔记二 编译自带的demo的步骤
2019-04-26
【Android平台】 Alljoyn学习笔记四 Android Core API参考
2019-04-26
【Alljoyn】Alljoyn学习笔记五 AllJoyn开源技术基础概念解析
2019-04-26
【Alljoyn】 Alljoyn学习笔记六 Alljoyn基本概念
2019-04-26
【Alljoyn】 Alljoyn学习笔记七 Alljoyn瘦客户端库介绍
2019-04-26
【Android】Activity生命周期
2019-04-26
【Android】Activity的四种launchMode
2019-04-26
【Android】Activity的task相关
2019-04-26
【Android】 Intent应用详解
2019-04-26
【Android】 Intent详解
2019-04-26
【Android】 常用的Intent
2019-04-26
Android中AsyncTask的简单用法
2019-04-26
【Android】 Android中Log调试详解
2019-04-26
【Android】Android中WIFI开发总结(二)
2019-04-26
【Android】Android之WiFi开发应用示例
2019-04-26
【Android】 Android adb常见问题整理
2019-04-26
【Android】 Android体系结构图
2019-04-26
【Android】 Android中spinner下拉列表的使用
2019-04-26
说说在 python 中,如何删除左右两边不需要的字符
2019-04-26