×

JS运算符:非(NOT)、与(AND)和或(OR)

作者:Web前端之家2020.07.16来源:Web前端之家浏览:246评论:0
关键词:js

布尔运算符的主要功能是测试两个值的关系,是条件语句和循环语句的基础,布尔运算符一共有3个:非(NOT)、与(AND)和或(OR)。

一、逻辑非

逻辑非操作符由一个叹号(!)表示,可以应用于ECMAScript中的任何值。无论这个值是什么数据类型,这个操作符都会返回一个布尔值。逻辑非操作符首先会将它的操作数转换为一个布尔值,然后再对其求反。逻辑非操作符遵循下列规则:

  1. 如果操作数是一个对象,返回false。

  2. 如果操作数是一个空字符串,返回true。

  3. 如果操作数是一个非空字符串,返回false。

  4. 如果操作数是数值0,返回true。

  5. 如果操作数是任意非0数值(包括Infinity),返回false。

  6. 如果操作数是null,返回true。

  7. 如果操作数是NaN,返回true。

  8. 如果操作数是undefined,返回true。

逻辑非操作符也可以用于讲一个值转换为与其对应的布尔值。同时使用两个逻辑非操作符,实际上就会模拟Boolean()转型函数的行为。其中,第一个逻辑非操作会基于无论什么操作数返回一个布尔值,而第二个逻辑非操作则对该布尔值求反,于是就得到了这个值真正对应的布尔值。

alert(!"blue"); //false
alert(!0); //true
alert(!!"blue"); //true
alert(!!0); //false

二、逻辑与

逻辑与操作符由两个和号(&&)表示,有两个操作数,逻辑与的真值表如下:

即两个操作数都为true的时候才返回true,否则返回false。

逻辑与操作可以应用于任何类型的操作数,而不仅仅是布尔值。在有一个操作数不是布尔值的情况下,逻辑与操作就不一定返回布尔值,此时它遵循下列规则:

  1. 如果第一个操作数是对象,则返回第二个操作数。

  2. 如果第二个操作数是对象,则只有在第一个操作数的求职结果为true的情况下才会返回该对象。

  3. 如果两个操作数都是对象,则返回第二个操作数。

  4. 如果有一个操作数为null,则返回null。

  5. 如果有一个操作数是undefined,则返回undefined。

逻辑与操作属于短路操作,即如果第一个操作数能够决定结果,那么就不会再对第二个操作数求值。对于逻辑与操作而言,如果第一个操作数是false,则无论第二个操作数是什么值,结果都不再可能是true了。另外,不能在逻辑与操作中使用未定义的值,这会导致错误。

var result = true || false;
var found = true;
var result = (found && someUndefinedVariable); //这里会发生错误
alert(result); //这一行不会执行
var found = false;
var result = (found && someUndefinedVariable); //短路操作,不会发生错误
alert(result); //false

三、逻辑或

逻辑或操作符由两个竖线符号(||)表示,有两个操作数,逻辑或的真值表如下:

两个操作数都为false的时候才返回false,否则返回true。

与逻辑与操作相似,如果有一个操作数不是布尔值,逻辑或也不一定返回布尔值,此时遵循下列规则:

  1. 如果第一个操作数是对象,则返回第一个操作数。

  2. 如果第一个操作数的求值结果为false,则返回第二个操作数。

  3. 如果两个操作数都是对象,则返回第一个操作数。

  4. 如果两个操作数都是null,则返回null。

  5. 如果两个操作数都是NaN,则返回NaN。

  6. 如果两个操作数都是undefined,则返回undefined。

与逻辑与操作符相似,逻辑或操作符也是短路操作符。也就是说,如果第一个操作数的求值结果为true,就不会对第二个操作数求值了。另外,同样不能在逻辑或操作中使用未定义的值,这会导致错误。

我们可以利用逻辑或的这一行为来避免为变量赋null或undefined值。

var myObject = preferredObject || backupObject;

变量myObject将被赋予等号后面两个值中的一个。变量preferredObject中包含优先赋给变量的值,若preferredObject中不包含有效值,则将变量backupObject中的值赋给变量myObject。ECMAScript程序的赋值语句经常使用这种模式。

温馨提示:本文作者系Web前端之家 ,经Web前端之家编辑修改或补充,转载请注明出处和本文链接:
https://jiangweishan.com/article/js20200716a1.html

网友评论文明上网理性发言 已有0人参与

发表评论:

最新留言

  • ajoy

    说法可以是一样的,毕竟JS和JQ都是有“血缘关系”的,你可以自己改下不就可以了吗,哈哈!...

  • 访客

    标题是JS用了JQ误人子弟呢...

  • absoy

    vue居然还能这么玩,期待你们vue3.0中文版教程。...

  • caij2

    github也中了新冠病毒了吧,哈哈!...

  • 访客

    收藏啦...

  • Web前端之家

    当然都可以被import,如何去设置,还要看你的具体项目要求。...

  • 访客

    exportdefault和vue的实例有啥子区别呢都可以被import...

  • Web前端之家

    可以加QQ群295431592咨询。...

首页|JavaScript|HTML|HTML4|HTML5|CSS3|开发工具|性能优化|移动开发|前端教程|性能优化|开发工具|酷站欣赏|UI设计|前端教程

Copyright © 2020 Web前端之家(www.jiangweishan.com) 版权所有 All Rights Reserved.
粤ICP备12067512号-1

Copyright Your WebSite.Some Rights Reserved.

Powered By Z-BlogPHP 1.6.4 Valyria