深入浅出代码优化﹣if/else

更新日期: 2018-10-27 阅读: 3.7k 标签: 优化

前言 

对于代码裡面的 if else,我们可以使用逻辑判断式,或更好的三元判断式来优化代码。除了可以降低维护项目的成本之外,还可以提升代码可读性。就让我们从最简单的 if else 例子开始吧。 

 最简单的 if...else... 或者 switch 都是 JavaScript 的入门,我们这裡就简单说一下:

if (workIsDone === true){
  eatDinner();
} else {
  keepCoding();
}


表达式与陈述句 

首先我们要了解什麽是表达式(Expressions),什麽是陈述句(Statements)。 

 表达式是任何句子用来给 JavaScript 引擎展开,并产生值。

 例如,它可以是一个数字,数组,对象,正则表达式,赋值,函数。 

陈述句这是任何句子用来给 JavaScript 引擎让某些事物发生,或者由副作用。

 例如:条件命令式,变量,循环,返回,try/catch/finally。


条件和真假值 

何为真?何为假?万物有所变,但 JavaScript 引擎却有所定义。 

 假 

我们可以简单地用 A == false 来判断假的值。

'' 或 "" 或 ``
0 或 -0
null
undefined
NaN
false

值得注意的是,使用模板字符串而裡面没有填充任何值的话,也是会返回 false 的。

 真 

非假为真 


如何优雅地写出条件判断式

还记得 De Morgan's Laws 吗? 

我们可以用它来简化複杂的条件判断式:

!(A || B) === (!A && !B) // true
!(A && B) === (!A || !B) // true


实战部分

对于 Google Analytics(GA),我们不希望把作者本人的数据,以及测试环境的数据也上传上去,以免干扰资料正确性。我们就可以问用户是否已经作者本人,以及是否在测试环境上,来判断是否需要寄送 Google Analytics 数据到 Google 服务器上。  

假设两个函数已经写好了,比如说 isAuthor() 和 isTestingEnvironment()。 只有在不是作者本人,或者当前环境不是测试环境,我们才寄送数据到 Google 服务器上。 

const enableGA = !(isAuthor() || isTestingEnvironment());
const betterEnableGA = !isAuthor() && !isTestingEnvironment();

当然,更加好的写法是只有当用户不是作者本人,以及不在测试环境上,我们才寄送数据到 Google 服务器上。

const enableGA = isNotAuthor() && isNotTestingEnvironment();


优化 if else 的不同手段

 以 && 取代单纯的 if 语句 

if (user && user.canDeletePost) {
  deletePost();
}

以上的代码可以取代为: 

user && user.canDeletePost && deletePost();

当然,如果你认为这样写的代码太长,会有副作用,那麽你可以简化为: 

const userCanDeletePost = user && user.canDeletePost;
userCanDeletePost && deletePost();


以 || 取代 if else 语句

 我们这裡会用一个判断用户密码长度的简单函数作为例子。如果你有更加好的代码片段,欢迎在底部的评论区留言。 

let strength = null;
    
if (password.length > 7) {
  strength = 'Strong';
} else {
  strength = 'Weak';
}

以上的代码可以取代为: 

const strength = (password.length > 7) && 'Strong' || 'Weak';

然而,使用 && 加 || 的组合会增加程序员阅读代码的思维层数,一种更加好的做法是使用三元运算符(ternary operator)。 

值得注意的是,如果你的 && 之后 的 A 是一个 falsy 的值,它永远不会返回,而是返回 B。

condition && A || B;
    
// 例如:
let password = 'abcdefg1234';
(password.length > 7) && false || 'Weak'; // 'Weak'

password = 'a';
(password.length > 7) && false || 'Weak'; // 'Weak'

 我们可以使用三元运算符而不是逻辑运算符来更好地表达语句。  


三元运算符 

最简单的三元运算符会是,条件为真?返回 A,不然返回 B。  

condition ? A : B;

针对以上的例子,判断密码长度的代码片段可以改为: 

const strength = (password.length > 7) ? 'Strong' : 'Weak';

另外一个例子,就是在支持多浏览器的 AJAX 库裡面可以得出的代码片段:

let xmlhttp = null;
    
if (window.XMLHttpRequest) {
  // 現代瀏覽器
  xmlhttp = new XMLHttpRequest();
} else if (window.ActiveXObject) {
  // 舊 IE 版本 (IE <= 6)
  xmlhttp = new ActiveXObject('Microsoft.XMLHTTP');
}

我们可以使用逻辑运算符来优化以上代码片段: 

const xmlhttp = window.XMLHttpRequest && new XMLHttpRequest()
      || window.ActiveXObject && new ActiveXObject('Microsoft.XMLHTTP')
      || null;

或使用更加好的三元运算符来优化以上代码片段:

const xmlhttp = window.XMLHttpRequest
  ? new XMLHttpRequest()
  : window.ActiveXObject
    ? new ActiveXObject('Microsoft.XMLHTTP')
    : null;

值得注意的是,三元判断式是从右到左结合的: 

// 這個判斷式
A ? B : C ? D : E ? F : G
    
// 等同以下判斷式
(A ? B : (C ? D : (E ? F : G))) // B

然而,你可能是想写: 

(((A ? B : C) ? D : E )? F : G) // F

所以,记得自己加括号来控制代码如何结合解析。 


 后记 

上个星期,组织举办了一场前端 Code Review 的大会,其中优化 if...else... 的手法,让我有所体悟。之后,我花了点时间研究逻辑判断式及三元判断式。希望能够达到知其然,知其所以然的阶段。

 对于第一段代码,我们可以简化为以下代码:  

workIsDone ? eatDinner() : keepCoding();


来自:https://calpa.me


本文内容仅供个人学习、研究或参考使用,不构成任何形式的决策建议、专业指导或法律依据。未经授权,禁止任何单位或个人以商业售卖、虚假宣传、侵权传播等非学习研究目的使用本文内容。如需分享或转载,请保留原文来源信息,不得篡改、删减内容或侵犯相关权益。感谢您的理解与支持!

链接: https://fly63.com/article/detial/1198

相关推荐

微信小程序代码优化总汇

写篇文章的目的,是以开放小程序代码的层面的优化。包括:条件判断将wx:if换成了hidden 、页面跳转请销毁之前使用的资源、列表的局部更新、小程序中多张图片懒加载方案、Input状态下隐藏input,应预留出键盘收起的时间

js中for循环优化总结_如何提高程序的执行效率

在程序开发中,经常会使用到for循环的,但是很多人写的for循环效率都是比较低的,下面就举例说明,并总结优化for循环的方法,来提高我们程序的执行效率。

通过HTML5 Video来优化动态GIF

网页中的动态GIF图片是非常受欢迎的,因为它们相比静态图片更生动,相比网页视频更简单。但是GIF图片通常具有较大的体积,就导致网页加载速度变慢,内存使用增加

网页首屏性能优化总结

本文总结了系统地进行前端性能优化的整体思路。具体到实施的过程,每一种优化方法都能搜到详细的文章,这里就不展开了。同时,还应该结合具体的业务场景对症下药,最终真正的提高用户体验。符合预期。

微信小程序性能优化入门指南

小程序从发布到现在也已经有将近两年的时间,越来越来多的公司开始重视小程序生态带来的流量,今年也由于小程序平台对外能力的越来越多的开放以及小程序平台的自身优化,越来越多的开发者也自主的投入到小程序的开发当中

css性能优化-will-change

will-change通过告知浏览器该元素会有哪些变化,使浏览器提前做好优化准备,增强页面渲染性能。不要将 will-change 应用到太多元素上,如果过度使用的话

JS性能优化之文档片段createDocumentFragment

DocumentFragments是DOM节点。它们不是主DOM树的一部分。通常的用例是创建文档片段,将元素附加到文档片段,然后将文档片段附加到DOM树。在DOM树中,文档片段被其所有的子元素所代替。因为文档片段存在于内存中,并不在DOM树中

MySQL查询优化

MySQL的查询怎么才能更快,更合理?除了加索引还有什么可以学习的呢?要想更好地学习某样东西,从其原理和运作方式入手更容易掌握。

网络串流播放_HTML5如何优化视频文件以便在网络上更快地串流播放

无论你正在将 GIF 动图转换为 MP4 视频,还是手头已经有一大堆 MP4 视频,你都可以优化文件结构,以使得这些视频更快地加载和播放。通过重组 atoms 将 moov 放到文件开头,浏览器可以避免发送额外的 HTTP range request 请求来搜寻和定位 moovatom

网站打开速度优化_如何提高网页访问速度技巧方法总结

网站的加载速度不仅影响着用户体验,也会影响搜索引擎的排名,在百度推出“闪电算法”以来,将网站首屏打开速度被列入优化排名行列,作为前端开发的我们需要如果来优化网站的打开速度呢?下面就整理挖掘出很多细节上可以提升性能的东西分享给大家

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!