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 |