--- title: 相等(==) slug: Web/JavaScript/Reference/Operators/Equality tags: - JavaScript - Reference translation_of: Web/JavaScript/Reference/Operators/Equality original_slug: Web/JavaScript/Reference/Operators/相等 ---
等于运算符(==
)检查其两个操作数是否相等,并返回Boolean
结果。与严格相等运算符(===
)不同,它会尝试强制类型转换并且比较不同类型的操作数。
x == y
相等运算符(==
和!=
)使用抽象相等比较算法比较两个操作数。可以大致概括如下:
true
。null
,另一个操作数是undefined
,则返回true
。Boolean
,则将布尔操作数转换为1或0。
true
,则转换为1
。false
,则转换为0
。valueOf()
和toString()
方法将对象转换为原始值。String
:true
仅当两个操作数具有相同顺序的相同字符时才返回。Number
:true
仅当两个操作数具有相同的值时才返回。+0
并被-0
视为相同的值。如果任一操作数为NaN
,则返回false
。Boolean
:true
仅当操作数为两个true
或两个false
时才返回true
。此运算符与严格等于(===
)运算符之间最显着的区别在于,严格等于运算符不尝试类型转换。相反,严格相等运算符始终将不同类型的操作数视为不同。
1 == 1; // true "hello" == "hello"; // true
"1" == 1; // true 1 == "1"; // true 0 == false; // true 0 == null; // false 0 == undefined; // false null == undefined; // true const number1 = new Number(3); const number2 = new Number(3); number1 == 3; // true number1 == number2; // false
const object1 = {"key": "value"} const object2 = {"key": "value"}; object1 == object2 // false object2 == object2 // true
请注意,使用构造的字符串new String()
是对象。如果将其中之一与字符串文字进行比较,则该String
对象将被转换为字符串文字并对其内容进行比较。但是,如果两个操作数都是String
对象,则将它们作为对象进行比较,并且必须引用相同的对象才能进行比较:
const string1 = "hello"; const string2 = String("hello"); const string3 = new String("hello"); const string4 = new String("hello"); console.log(string1 == string2); // true console.log(string1 == string3); // true console.log(string2 == string3); // true console.log(string3 == string4); // false console.log(string4 == string4); // true
const d = new Date('December 17, 1995 03:24:00'); const s = d.toString(); // for example: "Sun Dec 17 1995 03:24:00 GMT-0800 (Pacific Standard Time)" console.log(d == s); //true
规范 |
---|
{{SpecName('ESDraft', '#sec-equality-operators', 'Equality operators')}} |
{{Compat("javascript.operators.equality")}}