逻辑或(||)和逻辑与(&&)在许多编程语言中都有,大家都很熟悉,也许正因为如此,有很多人会觉得他们在JS中应该也没什么特别的,但是JS中它们不太一样。
和其他语言不同,在JS中它们返回的并不一定是布尔值。它们返回的值是两个操作数中的一个(且仅一个)。
例如:
var a = 42;
var b = "csdn";
var c = null;
a || b; //返回值是:42
a && b; //返回值是:"csdn"
c || b; //返回值是:"csdn"
c && b; //返回值是:null
在C和PHP中,上面的结果是true或false,但是在JS(以及Python和Ruby)中却是某个操作数的值。
个人总结的处理原理如下:
在JS中逻辑运算符操作中(无论是||还是&&),首先会对第一个操作数执行条件判断,如果不是布尔值就先进行强制类型转换,然后在执行条件判断,整个表达式返回的结果是:“能够决定整个逻辑运算表达式的结果(这里指C类语言中的结果,以下省略标识)的那个操作数的值”!
比如上面的 a || b 表达式中,先把a转换为布尔值true,当a为真,整个表达式的结果就为真,所以是a决定了整个表达式的结果,所以JS中整个表达式的返回结果就是 a 的值。
再比如a && b中,a为真时并不能决定整个表达式的结果,需要继续判断b,如果b为真,则为真,如果b为假,则为假,所以是b决定了整个表达式的结果,所以JS中整个表达式的返回结果就是b的值。
以此类推,另外两个也是如此!!!
所以JS中整个逻辑运算表达式返回的结果是:“能够决定整个逻辑运算表达式的结果的那个操作数的值”!
注:目前的这个结论是本人的个人总结的结论,如果有不严谨的地方,欢迎各位批评指正,谢谢!