| 等值检测运算符 | 说明 | 
|---|---|
| ==(相等) | 比较两个操作数的值是否相等 | 
| !=(不想等) | 比较两个操作数的值是否不相等 | 
| ===(全等) | 比较两个操作数的值是否相等,同时检测它们的类型是否相同 | 
| !==(不全等) | 比较两个操作数的值是否不相等,同时检测它们的类型是否不相同 | 
console.log("1" == 1);  //返回true。字符串被转换为数字
console.log(true == 1);  //返回true。true被转换为1
console.log(false == 0);  //返回true。false被转换为0
console.log(null == 0);  //返回false
console.log(undefined == 0);  //返回false
console.log(undefined == null);  //返回true
console.log(NaN == "NaN");  //返回false
console.log(NaN ==1);  //返回false
console.log(NaN == NaN);  //返回false
console.log(NaN != NaN);  //返回true
NaN与任何值都不相等,包括它自己。null 和 undefined 值相等,但是它们是不同类型的数据。在相等比较中,null 和 undefined 不允许被转换为其他类型的值。
var a = "abc" + "d"; var b = "a" + "bcd"; console.log(a == b); //返回true数值和布尔值的相等比较运算效率比较高,而字符串需要逐个字符进行比较,相等比较运算效率比较低。
console.log(null === undefined); //返回false console.log(0 === "0"); //返回false console.log(0 === false); //返回false
var a = {};
var b = a;
console.log(a === b);  //返回true
下面两个对象虽然结构相同,但是地址不同,所以不全等。
var a = {};
var b = {};
console.log(a === b);  //返回false
var a = new String("abcd);  //定义字符串“abcd”对象
var b = new String("abcd);  //定义字符串“abcd”对象
console.log(a === b);  //返回false
console.log(a == b);  //返回false
在上面示例中,两个对象的值相等,但是引用地址不同,所以它们既不想等,也不全等。因此,对于复合型对象来说,相等==和全等===运算的结果是相同的。
var a = "1" + 1; var b = "11"; console.log(a ===b); //返回true
var a = 1; var b = 2; console.log((a > b || a == b) == (a >= b)); //返回true,此时似乎相等如果为变量 a 和 b 分别赋值 null 和 undefined,则返回值 false,说明这两个表达式并非完全等价。
var a = null; var b = undefined; console.log((a > b || a == b) == (a >= b)); //返回false,表达式的值并非相等因为 null == undefined 等于 true,所以表达式(a > b || a == b)的返回值为 true,但是表达式 null >= undefined 的返回值为 false。
 版权说明:
	  版权说明:Copyright © 广州松河信息科技有限公司 2005-2025 版权所有 粤ICP备16019765号
广州松河信息科技有限公司 版权所有 18520775521
18520775521



 QQ洽谈
QQ洽谈
 sales@itwy.com
sales@itwy.com
