js中的 || 与 && 运算符详解

前端之家收集整理的这篇文章主要介绍了js中的 || 与 && 运算符详解前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

js中逻辑运算符在开发中可以算是比较常见的运算符了,主要有三种:逻辑与&&、逻辑或||和逻辑非!。@H_404_1@

当&&和|| 连接语句时,两边的语句会转化为布尔类型(Boolean),然后再进行运算,具体的运算规则如下:@H_404_1@

1.&&

@H_404_1@

1.1两边条件都为true时,结果才为true; 1.2如果有一个为false,结果就为false; 1.3当第一个条件为false时,就不再判断后面的条件@H_404_1@

注意:当数值参与逻辑与运算时,结果为true,那么会返回的会是第二个为真的值;如果结果为false,返回的会是第一个为假的值。@H_404_1@

2.||

@H_404_1@

2.1只要有一个条件为true时,结果就为true; 2.2当两个条件都为false时,结果才为false; 2.3当一个条件为true时,后面的条件不再判断@H_404_1@

注意:当数值参与逻辑或运算时,结果为true,会返回第一个为真的值;如果结果为false,会返回第二个为假的值;@H_404_1@

3.!@H_404_1@

3.1当条件为false时,结果为true;反之亦然。@H_404_1@

代码说明:@H_404_1@

<Meta charset="UTF-8"> demo

补充:逻辑与的优先级是高于逻辑或的;@H_404_1@

比如console.log(3||2&&5||0),会先算2&&5的值为5,然后再3||5----3,最后再3||0----3,所以最终结果为3.@H_404_1@

补充

@H_404_1@

表达式a && 表达式b : 计算表达式a(也可以是函数)的运算结果, 如果为 True,执行表达式b(或函数),并返回b的结果; 如果为 False,返回a的结果;@H_404_1@

表达式a || 表达式b : 计算表达式a(也可以是函数)的运算结果, 如果为 Fasle,执行表达式b(或函数),并返回b的结果; 如果为 True,返回a的结果;@H_404_1@

转换规则:@H_404_1@

对象为true; 非零数字为true;@H_404_1@

零为false;@H_404_1@

非空字符串为true; 空字符串为法false; 其他为false;@H_404_1@

例如: var a = obj || " " ; //如果 obj 为空,a就赋值为 " " ; var a = check() && do(); //如果check()返回为真,就执行do(),并将结果赋值给 a;@H_404_1@

其他网友的补充

@H_404_1@

今天复习js继承的时候发现了一个问题,先上代码了@H_404_1@

在执行构造函数的时候,无参的构造函数返回的name是'mama',有参数时,实例的name就是参数值了。 这个时候我就有点犯迷糊了,为什么逻辑运算符||能这么用呢? 由于是C#出身,所以对js ||这样用感觉很奇怪。 没辙,不懂先研究,实验实验就知道了。@H_404_1@

换成别的呢?@H_404_1@

@H_404_1@@H_404_1@

通过这几个实验,可以看出,JS的||并不是像C#里面的||一样 单纯的返回一个布尔类型。 大家都知道js的布尔类型判定是对象是true,非零是true,非空字符串是true其余的都是false@H_404_1@

由此得出 逻辑或 || : var a = 表达式1 || 表达式2@H_404_1@

      表达式1    表达式2    a取值        1       0      表达式1结果值        1        1      表达式1结果值        0        1      表达式2结果值        0        0      表达式2结果值 @H_404_1@

逻辑与 && : var a = 表达式1 && 表达式2@H_404_1@

      表达式1    表达式2    a取值@H_404_1@

       1       0      表达式2结果值        1        1      表达式2结果值        0        1      表达式1结果值        0        0      表达式1结果值@H_404_1@

主要原因是因为短路,逻辑或 || 在前面有一个ture的时候则不看后面直接停止,逻辑与&&同理。 然后计算赋值和我们平时一样之获取最新的一次计算结果值。@H_404_1@

例如@H_404_1@

嘛嘛,当然只是猜测。 以上仅供参考。萌新一只,望各位大佬轻批。@H_404_1@

猜你在找的JavaScript相关文章