您的位置:首页 > 数码常识数码常识

js条件判断语句(js条件判断)

2025-05-12人已围观

js条件判断语句(js条件判断)
  经常code review,我发现JS newbie很容易写出一堆冗长的代码。今天就列几个比较常见的“解决之道”,看看如何减少JS里的条件判断。

  js条件判断

  提前返回,少用if...else

  “if...else是编程语言的精华。——鲁迅”但是过多的嵌套,还是挺令人抓狂的。这里有一个很典型的条件嵌套:

  这种嵌套的特点就是else里的代码块很小,但是由于不得不做的分支语句导致多层嵌套。动动脑筋,怎样精简一下呢?在if里做非判断——条件反转,并通过卫语句提前return else分支。

  forEach优化

  遍历的时候也经常产生大量的嵌套,如下代码所示,我们先对数组元素做一次合法性校验,通过后再做一次新的操作,最后把操作结果追加到新数组里。

  仔细观察这就是一个filter加map的过程。我们不妨试试函数式编程:

  我自己是一名从事了多年开发的web前端老程序员,目前辞职在做自己的web前端私人定制课程,今年年初我花了一个月整理了一份最适合2019年学习的web前端学习干货,各种框架都有整理,送给每一位前端小伙伴,想要获取的可以关注我的并在后台私信我:前端,即可免费获取。

  多条件,用Array.includes

  再举个例子,某个页面需要检验输入type是否合法。我收到过一个MR曾经是这么写的。

  如果合法的类型只有两种,代码其实也没啥问题。只是一般的业务很容易有后续的延展。今后将合法类型增加到10种的话,上述代码里将是一大长串的if判断。这种代码可读性极差,我们不如转换一下思想,把非法类型储到数组里,用Array.includes来帮你完成冗长的判断。之后每增加一种新的类型,只需在数组后追加新字符串就行了。

  使用object索引

  类似的情况也出现在三元表达式里:

  我们现阶段多语言只有en和zh,上述代码自然不是问题,但是也难保哪天会支持日语——ja。这时候再写成下面这类代码就很搞笑了:

  比较合适的写法就是使用object键索引,这样当语言业务扩展后,只需要在localeFormats后追加新格式就行了。

  尽量少用swith

  长Switch也及其难看。

  我记得OOP设计模式里提到过:尽量使用多态和继承代替Switch结构。JS里倒不必非得往这方面想,用Object或是Map索引来代替Switch也是极好滴!

  Optional Chaining

  Optional Chaining(以下简称OC)是我极力推荐的一个语法糖。我写过一期《Javascript Optional Chaining》具体介绍它的用法,有兴趣的小伙伴可以看一看,这里稍微点一下。比如我们想获取地址里的街道信息,但是并不确定地址本身是否存在,因此只能在获取街道前,事先判断一下地址合法性,一般我们会这么写:

  但假如再多一层呢,从basicInfo.address.street这样找下来呢?

  上面的代码我已经觉得很丑陋了,再多个几层真是没法看了。不过不用担心,有了OC一切迎刃而解。(虽然OC还在ECMAScript stage2,但是大家可以用babel尝鲜;babel会自动把如下源码转义成上面的形式)

  写在最后

  自学过几种编程语言,我感觉这类小技巧在各类语言中大同小异;实现上也许有细微差别,但基本思想都是一样的——减少大括号的数量!!我在面试的时候经常看到一些人写代码及其冗长,嵌套极多。我提醒后,得到的回复一般是:“我没做过这种面试”,“我熟悉的是另外一种语言”等等。回过头来再想想,这真的是好理由吗?

  上面就是小居数码小编今天给大家介绍的关于(js条件判断)的全部内容,希望可以帮助到你,想了解更多关于数码知识的问题,欢迎关注我们,并收藏,转发,分享。

  94%的朋友还想知道的:

  设置excel条件格式图文教程(如何设置excel条件格式)

  excel筛选条件怎么设置(Excel筛选怎么设置)

  mysql增删改查语句以及常用方法(mysql怎么建立数据库)

  mysql优化工具mysqltuner(mysql语句优化使用什么工具)



  155255
 

很赞哦! ()

随机图文