John Au-Yeung
来源:medium
译者:前端小智
点赞再看,养成习惯本文
GitHub
https://github.com/qq44924588... 上已经收录,更多往期高赞文章的分类,也整理了不少个人文档,和教程资料。欢迎Star和完善,你们面试能够参照考点复习,但愿咱们一块儿有点东西。javascript
JavaScript 是一种易于学习的编程语言,编写运行并执行某些操做的程序很容易。然而,要编写一段干净的JavaScript 代码是很困难的。前端
在本文中,咱们将介绍一些优化条件表达式相关的重构思路。java
咱们能够将长的条件表达式分解成有命名的短小条件表达多,这样有利于阅读。例如咱们可能会写这样的代码:git
let ieIEMac = navigator.userAgent.toLowerCase().includes("mac") && navigator.userAgent.toLowerCase().includes("ie")
上面的代码太过冗长了,不利于阅读,咱们能够把它分解成几个短小且有名字的条件表达式,以下所示:github
let userAgent = navigator.userAgent.toLowerCase(); let isMac = userAgent.includes("mac"); let isIE = userAgent.toLowerCase().includes("ie"); let isMacIE = isMac && isIE;
与上面相反的,若是有多个简短的条件表达式,则能够将它们合并成一个。例如咱们可能会写这样的代码:面试
const x = 5; const bigEnough = x > 5; const smallEnough = x < 6; const inRange = bigEnough && smallEnough;
咱们能够这样合并:编程
const x = 5; const inRange = x > 5 && x < 6;
由于表达式很短,即便把它们组合在一块儿也不会使表达式变长,因此咱们能够这样作。微信
若是咱们在条件块中有重复的表达式或语句,则能够将它们移出。例如咱们可能会写这样的代码:编程语言
if (price > 100) { //... complete(); } else { //... complete(); }
咱们能够把重复的内容移到条件表达式外面,以下所示:函数
if (price > 100) { //... } else { //... } complete();
这样,咱们没必要重复没必要要地调用complete
函数。
若是咱们在循环中使用了控制标志,那应该会这样代码:
let done = false; while (!done) { if (condition) { done = true; } //... }
在上面的代码中,done
是控制标,在condition
为true
时,将done
设置为true
中止while
循环。
相对于上面,咱们可使用break
来中止循环,以下所示:
let done = false; while (!done) { if (condition) { break; } //... }
卫语句就是把复杂的条件表达式拆分红多个条件表达式,好比一个很复杂的表达式,嵌套了好几层的if-then-else
语句,转换为多个if
语句,实现它的逻辑,这多条的if
语句就是卫语句。
嵌套条件语句很难阅读,因此咱们可使用卫语句代替它们。例如咱们可能会写这样的代码:
const fn = () => { if (foo) { if (bar) { if (baz) { //... } } } }
咱们能够这样优化:
if (!foo) { return; } if (!bar) { return; } if (baz) { //... } }
在上面的代码中,卫语句是:
if (!foo) { return; }
和
if (!bar) { return; }
若是这些条件为假,它们会提早返回函数,这样,咱们就不须要嵌套了。
咱们可使用switch
语句为不一样种类的数据建立相同的子类,而不是使用switch
语句对不一样类型的数据执行相同的操做,而后针对对象的类型使用不一样的方法。
例如咱们可能会写这样的代码:
class Animal { constructor(type) { this.type = type; } getBaseSpeed() { return 100; } getSpeed() { switch (this.type) { case ('cat'): { return getBaseSpeed() * 1.5 } case ('dog'): { return getBaseSpeed() * 2 } default: { return getBaseSpeed() } } } }
咱们能够这样重构:
class Animal { constructor(type) { this.type = type; } getBaseSpeed() { return 100; } } class Cat extends Animal { getSpeed() { return super.getBaseSpeed() * 1.5; } } class Dog extends Animal { getSpeed() { return super.getBaseSpeed() * 2; } }
当switch
语句很长时,应该为不一样类型的对象定制case
块。
若是咱们重复检查null
或undefined
,则能够定义一个表明该类的null
或undefined
版本的子类,而后使用它。
例如咱们可能会写这样的代码:
class Person { //... }
咱们能够这样重构:
class Person { //... } class NullPerson extends Person { //... }
而后,咱们将Person
设置为null
或undefined
的对象属性,而不是将其设置为NullPerson实例。
这样就无需使用条件检查这些值。
代码部署后可能存在的BUG无法实时知道,过后为了解决这些BUG,花了大量的时间进行log 调试,这边顺便给你们推荐一个好用的BUG监控工具 Fundebug。
原文:https://levelup.gitconnected....
文章每周持续更新,能够微信搜索「 大迁世界 」第一时间阅读和催更(比博客早一到两篇哟),本文 GitHub https://github.com/qq449245884/xiaozhi 已经收录,整理了不少个人文档,欢迎Star和完善,你们面试能够参照考点复习,另外关注公众号,后台回复福利,便可看到福利,你懂的。