JavaScript基础知识--逻辑表达式的另一个层面
分成两个部分讲
逻辑与:&&
第一层理解: x == 0 && y == 0 ; //如果x 和 y都是0的话,那结果就返回true,反之任意一个不为0 返回false
这种理解很简单,求交集的结果
第二层理解: "&&" 可以对真值和假值进行布尔与(AND)运算。
第三层理解: 运算的顺序是从左往右的推进的,就是说如果 x == 0 ,那继续计算 y == 0的情况,保持计算的前进性
示例:
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这个值。非常有用