JS学习之 && 和 ||

Posted 走在程序的路上

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JS学习之 && 和 ||相关的知识,希望对你有一定的参考价值。

在js中,转换成false的有:

undefined       null     NaN    ‘‘   0      flase

其他都是true,即使是字符串‘false‘它也是是true

a || b , 条件满足一个就可以,如果a是true,那么b不管是true,false都返回true,因此就不用判断b了,返回a

    如果a是false,就必须要判断b,就返回b的值,所以不管b是true还是false 都返回b的值

a && b,并且,两个都要满足,如果a为false,后面的b不管是true还是false都不会被判断,返回a的值

如果a为true,就要判断b,所以不管b是true还是false 都返回b的值

来个复杂的例子(注意一点:在js中&&运算符优先级大于||)

假设:

 var a=new Object(),b=0,c=Number.NaN,d=1,e="Hello"; 

  alert(a || b && c || d && e);  表达式从左往右执行,先&&后||

    1、(b && c):b是false,此时不需要判断c,因为不管c是true是false,最终结果一定是false,因此返回当前判断对象b,也就是0;

    2、(d && e):d是true,这个时候判断e,此时不管e是true,是false,返回结果一定是e,e为true,因此返回"Hello";

    3、(a || b):a是true,此时不管b是true是false,结果都是true,所以不判断b,所以返回当前判断对象a,因此返回new Object();

    4、(a || e):同上,因此返回a。

这个表达式最终结果为a,也就是new Object()

以上是关于JS学习之 && 和 ||的主要内容,如果未能解决你的问题,请参考以下文章

27.28. VUE学习之--事件修饰符之stop&capture&self&once实例详解

Linux学习-Docker学习之Dockerfile

Promise--实践练习之fs模块 & node运行Js脚本 & Promise封装练习-fs模块 & util.promisify方法

node.js学习之swig

vue.js学习之 跨域请求代理与axios传参

vue.js 学习之模板语法详解