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这个值。非常有用

posted @ 2013-01-14 21:35  爱吃猫的鱼  阅读(191)  评论(0编辑  收藏  举报