js中的&&和||运算符
一个函数结果产生的思考~
function fn(){
return undefined&&1;
}
fn();
// 结果为 undefined
按照正常的逻辑 fn 应该返回的是false,但是结果却是 undefined
经过实验发现如果 && 和 || 两边的操作数不是布尔值,那么运算结果并不是布尔值,比如:
console.log(""&&"12321")
// ""
console.log(1&&"12321")
// "12321"
console.log(0&&1)
// 0
console.log(""||1)
// 1
console.log(1&&0)
// 0
个人认为是js将运算符两边的操作数隐式转换成布尔值之后再计算,可以最终得到是一个布尔值,但是是对应的操作的值。
比如console.log(""&&"12321")
,首先将操作数转换为布尔值计算,也就是false&&true
(当然这只是举例子,实际 && 运算,如果第一个操作数为false,就不再关心第二个操作数),再计算结果为false,然后最后得到false对应的操作数。
同样,console.log(1||2)
结果为1,为什么不是2呢,同样将操作数变为true||true
,结果为true。因为是||运算符。