Javascript 中的 && 和 || 使用小结

普通情况下的 && 和 || 比较简单,这里不进行讨论。 

准备两个对象用于下面的讨论。 

代码如下:

var alice = { 
name: "alice", 
toString: function () { 
return this.name; 



var smith = { 
name: "smith", 
toString: function () { 
return this.name; 


在 javascript 中,对于 && 不仅仅可以用于 boolean 类型,也不仅仅返回 Boolean 类型的结果。 
l 如果第一个操作数是 Boolean 类型,而且值为 false ,那么直接返回 false。 
l 如果第一个操作数是 Boolean 类型,而且值为 true,另外一个操作数是 object 类型,那么将返回这个对象。 
l 如果两个操作数都是 object 类型,那么,返回第二个对象。 
l 如果任何一个操作数是 null,那么,返回 null。 
l 如果任何一个操作数是 NaN,那么返回 NaN。 
l 如果任何一个操作数是 undefinded,那么返回 undefined。 


alert(false && alice); // false 
alert(true && alice); // alice 

alert(alice && smith); // smith 
alert(smith && alice); // alice 

alert(null && alice); // null 
alert(NaN && alice); // NaN 
alert(undefined && alice); // undefined 
alert(alice && undefined); // undefined 

对于 || 来说,同样也不仅仅用于 Boolean 类型,也不仅仅返回 Boolean 类型的结果。 
事实上,null、undefined、NaN 都将被看作 false。而对象被当作 true。 

l 如果第一个操作数是 boolean 类型,而且值为 true, 那么,直接返回 true。 
l 如果第一个操作数是 Boolean 类型,而且值为 false ,第二个操作数为 object,那么返回 object 对象。 
l 如果两个操作数都是 object 类型,那么返回第一个对象。 
l 如果两个操作数都是 null,那么,返回 null。 
l 如果两个操作数都是 NaN,那么返回 NaN。 
l 如果两个操作数都是 undefined,那么,返回 undefined。 
alert(false || alice);         // alice

 

alert(true || alice);          // true

alert(alice || smith);         // alice

alert(smith || alice);         // smith

alert(null || alice);       // alice

alert(alice || null);       // alice

alert(null || null);        // null

alert(NaN || alice);        // alice

alert(alice || NaN);        // alice

alert(NaN || NaN);          // NaN

alert(undefined || alice);     // alice

alert(alice || undefined);     // alice

alert(undefined || undefined); // undefined

不用搞得这么复杂 推荐大家看这部分的说明
a && b : 将a, b转换为Boolean类型, 再执行逻辑与, true返回b, false返回a 
a || b : 将a, b转换为Boolean类型, 再执行逻辑或, true返回a, false返回b 
转换规则: 
对象为true 
非零数字为true 
非空字符串为true 
其他为false 

  

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。