Javascript 中的 && 和 ||

王朝学院·作者佚名  2010-04-26
窄屏简体版  字體: |||超大  

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

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航