JavaScript基础知识--逻辑表达式的另一个层面

举报
~大鱼~ 发表于 2021/05/27 18:47:13 2021/05/27
【摘要】 分成两个部分讲 逻辑与:&& 第一层理解: x == 0 && y == 0 ; //如果x 和 y都是0的话,那结果就返回true,反之任意一个不为0 返回false 这种理解很简单,求交集的结果   第二层理解: “&&” 可以对真值和假值进行布尔与(AND)运算。   第三层理解: 运算的顺序是从左往右...

分成两个部分讲

逻辑与:&&

第一层理解: x == 0 && y == 0 ; //如果x 和 y都是0的话,那结果就返回true,反之任意一个不为0 返回false

这种理解很简单,求交集的结果

 

第二层理解: “&&” 可以对真值和假值进行布尔与(AND)运算。

 

第三层理解: 运算的顺序是从左往右的推进的,就是说如果 x == 0 ,那继续计算 y == 0的情况,保持计算的前进性

《JavaScript基础知识--逻辑表达式的另一个层面》

示例:

var obj = {x : “1”,y : “2”};

alert(obj&&obj.x);

这个时候,obj不是null,左侧的值为true,直接计算机obj.x的值

&&的这种行为有时被称为“短路”(看起来是不是很酷呢?如果在正规的项目,请遵守相关的代码规范,团队项目中不需要大神的级的代码风格;如果只是自己写的玩玩,想怎么奇葩,就怎么奇葩)

if(a == b) {stop();} 

a==b&&stop();等价的

 

逻辑或||

常用用法

x == 0 || y == 0;

如果x的值为0或者y的值为0的值时候,那整个式子的值为true,相反为false

从第二个层面的来看,如果左侧的值为false,那计算下一个式子的值,直到找到真值为止

示例:为一个变量赋上默认值

var height = person.height || father.height || 500;

如果person和father都没有height这个属性的话,那直接同上500这个值。非常有用

文章来源: brucedone.com,作者:大鱼的鱼塘,版权归原作者所有,如需转载,请联系作者。

原文链接:brucedone.com/archives/288

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。