js中的逻辑与(&&)和逻辑或(||)

Posted 我思固我在

tags:

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

之前有一个同事去面试,面试过程中碰到这样一个问题:

在js中写出如下的答案 :

var a = 2;

var b = 3;

var andflag = a && b ;

var orflag = a || b;

问andflag 和orflag 分别是什么?

起初我认为: andflag 和orflag 的值都为 true; 毕竟 && 和 || 都是求Boolean ,后来发现,我错了。

答案应该是  andflag  = 3,orflag = 2;

原因是这样的:

在运算过程中,首先js  会将 && 和||  两边的值转成Boolean 类型,然后再算值 ,&&运算如果返回true,则取后面的值,如果|| 返回true,则取前面的值 , 而其中数值转换成boolean 的规则 是:

对象、非零整数、非空字符串返回true,

其它为false   ;

a && b  的运算就是  :因为  a  和  b全是非零整数,所以  a  和  b  也就是true ,而   true && true  返回   true   ,则取后面的b   ,同理  a 和b 全是非零整数,a  和b  全是true  ,则true || true  返回   true ,取|| 前面的值 也就是2;

 

同样:该逻辑运算符支持短路原则:

如 var  a = “”  ||  null  || 3  ||  4   —->    var a = fasel || false || true ||  true  结果为true  则返回第一个true,即是3

var b = 4 && 5 && null && 0   ——>   var b = true && true && false && false   结果是false   则返回第一个false   即是null .

以上是关于js中的逻辑与(&&)和逻辑或(||)的主要内容,如果未能解决你的问题,请参考以下文章

js 非布尔值操作 逻辑与 和 逻辑或*

JS && || 陷阱 javascript 逻辑与逻辑或

你不得不知的逻辑或(||)与(&&)非(!)

js中的|| 与 &&

JS中短路运算符&&和||

JS中短路运算符&&和||