等于运算符(==
)检查其两个操作数是否相等,并返回Boolean
结果。与严格相等运算符(===
)不同,它会尝试强制类型转换并且比较不同类型的操作数。
详解:
相等运算符(
==
和!=
)使用抽象相等比较算法比较两个操作数。可以大致概括如下:
- 如果两个操作数都是对象,则仅当两个操作数都引用同一个对象时才返回
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
。此运算符与严格等于(
===
)运算符之间最显着的区别在于,严格等于运算符不尝试类型转换。相反,严格相等运算符始终将不同类型的操作数视为不同。
对象比较
var obj1 = {};
var obj2 = {};
console.log(obj1 == obj2); // false
console.log(obj1 == true); //false
console.log(obj1 == false); // false
console.log(obj1 == undefined); // false
console.log(obj1 == null); // false
console.log(undefined == null); //true
字符串比较
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