-1 == true; // false
-1 == false // false
-1 ? true : false; // true
谁能解释上面的输出?我知道我可以通过与 0 进行比较来解决这个问题,但我很感兴趣。我希望至少有一个草率的 equals 语句在进行隐式类型转换时是正确的,而且我当然没想到三元组会得出完全不同的结果。
-1 == true; // false
-1 == false // false
-1 ? true : false; // true
谁能解释上面的输出?我知道我可以通过与 0 进行比较来解决这个问题,但我很感兴趣。我希望至少有一个草率的 equals 语句在进行隐式类型转换时是正确的,而且我当然没想到三元组会得出完全不同的结果。
在前两种情况下,布尔值被转换为一个数字 - 1 代表true, 0 代表false。在最后一种情况下,它是一个转换为布尔值的数字,除 0 和 NaN 之外的任何数字都将转换为true。所以你的测试用例真的更像这样:
-1 == 1; // false
-1 == 0; // false
true ? true : false; // true
任何不是 0 或 1 的数字也是如此。
有关更多详细信息,请阅读 ECMAScript 文档。从第3 版 [PDF],第11.9.3 节抽象相等比较算法:
19 . 如果 Type(y) 是 Boolean,则返回比较结果 x == ToNumber(y)。
值得一读完整的算法,因为其他类型可能会导致更糟糕的陷阱。
在大多数系统中,非零值被视为真值,但这并不一定意味着它们与true
. 因此,-1 == true
不一定成立,但-1
仍然可以被认为是一个真值,因为它是非零的。
但是,实际上,如果可以避免的话,您不应该将整数与布尔值进行比较。
当评估为测试条件时,像 -1、5 和 17,000,000 这样的整数都返回Boolean true,因为它们在逻辑上评估为 true,例如
if(-1) {
"This is true";
}
else {
"This is false";
}
=> "This is true";
(注:0 逻辑上计算为假)
使用 ”?” 操作员做了这段代码所做的事情。它将第一个参数作为if语句中的条件传递,将第二个参数作为真情况传递,并将第三个参数作为假情况传递。
因此,第三个结果。
但是,这些整数与true的类型不同。
True是Boolean类型,-1、5 和 17,000,000是Integer类型。
就类型比较而言,比较“==”是严格的。即使两个事物具有相同的“值”,但类型不同,“==”运算符也会返回false:
if(6 == true) {
"This is true";
}
else {
"This is false";
}
=> "This is false";
甚至以下内容也会返回 false,因为"true"属于String类型,而true属于Boolean类型:
if("true" == true) {
"This is true";
}
else {
"This is false";
}
=> "This is false";
因此,前两个结果。
注意:如果您想比较不同类型的值,请使用“===”运算符:
if(6 === true) {
"This is true";
}
else {
"This is false";
}
=> "This is true";
并且,
if("true" === true) {
"This is true";
}
else {
"This is false";
}
=> "This is true";
希望这可以帮助!