JavaScript基础:逻辑运算符——&&和||(短路判断)和!

一、&&:所有条件都为true,返回true;只要有一个是false,返回false;不一定返回boolean类型值

1、可以操作任意类型的数据,不只是布尔型;(除了null、undefined、NaN不会隐式转换)

var a = 33,b=55,c=88

console.log(a<b&&b<c);//返回true

如果在有一个操作数不是布尔值得情况下,逻辑与就不一定返回布尔值,此时它遵循下列规则

  • 如果前面操作数隐式类型转换后为true,则返回最后一个操作数:

          console.log(77&&33);//返回33

          console.log(true&&9&&"您好");//返回“您好”

          console.log(80 && true );//返回true

  • 如果前面有一个隐式转换后不是true,则返回第一个隐式转换为false的值(即短路的值)

          console.log(“”&&true);//返回空格

          console.log(44&&0&&"hello");//返回0

          console.log(55&&false&&0);//返回false

          console.log(0&&null&&55);//返回0

          console.log(NaN && 16 && "");//返回NaN

          console.log("" && NaN && 12);//返回“”空字符串

2、返回值不一定是boolean类型。null,返回null;undefined,返回undefined;NaN,返回NaN

          console.log(55*“abc”&&true);//返回NaN

          console.log(null&&true);//返回null

          console.log(undefined&&true);//返回undefined

          console.log(undefined&&null&&9&&NaN);//返回undefined

 

二、||:只要一个条件为true,则返回true;都为false,则返回false

1、可以操作任意类型的数据,不只是布尔型;

2、返回值不一定是boolean类型。

(有一个为true,则返回true,后面就被短路啦;都为false,一直走到最后一个,打印左后一个)

          console.log(33<22||33>11);//返回true

          console.log(undefined || null || 0);//返回0

          console.log(undefined || 88 || 99 );//返回88

          console.lof(undefined || 33>10 || false);//返回true 

          console.log(null || undefined || NaN);//返回NaN

          console.log(NaN || undefined) ;//返回undefined

          console.log("hellow" || NaN);//返回hellow

 

三、!(逻辑非):返回值一定是boolean值

 

1、可以操作任意类型的数据,返回值一定是boolean值;

2、!!同事使用两个逻辑非操作符时——两次求反,为本来代表的boolean值

          console.log(!false);//true

          console.log(!88);//false

          console.log(!NaN);//true

          console.log(!!NaN);//false

          console.log(!!"hell");//true

转载于:https://www.cnblogs.com/qiong2017/p/7728336.html

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值