js-5:==和===的区别,分别在什么情况下使用

1、等于操作符
等于操作符用两个等号(==)表示,如果操作数相等,则返回true。
javascript中存在隐式转换,等于操作符在比较中会先进行类型转换,再确定操作数是否相等。
遵循以下规则:
如果任一操作数是布尔值,则将其转化为数值再比较是否相等。
在这里插入图片描述
如果操作数是字符串,另一个操作数是数值,则尝试将字符串转换为数值,再比较是否相等。
在这里插入图片描述
如果一个操作数是对象,另一个操作数不是,则调用对象valueOf()方法取得其原始值,再根据前面的规则进行比较。
在这里插入图片描述
null和undefined相等
在这里插入图片描述
如果有任一操作数是NaN,则相等操作符返回false。
在这里插入图片描述
如果两个操作数都是对象,则比较它们是不是同一个对象,如果两个操作数都指向同一个对象,则相等操作符返回true
js-5:==和===的区别,分别在什么情况下使用_第1张图片
小结:
两个都为简单类型,字符串和布尔值都会转换成数值,再比较。
简单类型与引用类型比较,对象转化成其原始类型的值,再比较。
两个都为引用类型,则比较它们是否指向同一个对象。
null和undefined相等。
存在NaN则返回false

2、全等操作符
全等操作符(===)表示只有在两个操作数在不转换的前提下相等才返回true,即类型相同,值也需要相同。
在这里插入图片描述
undefined与null与自身严格相等。
在这里插入图片描述

3、区别
相等操作符会做类型转换,再进行值的比较,全等操作符不会做类型转换。

在这里插入图片描述
null和undefined比较,相等操作符为true,全等为false
在这里插入图片描述
4、小结
相等运算符隐藏的类型转换,会带来一些违反直觉的结果。
js-5:==和===的区别,分别在什么情况下使用_第2张图片
但在比较null的情况的时候,一般使用相等操作符(

js-5:==和===的区别,分别在什么情况下使用_第3张图片
等同于下面写法
js-5:==和===的区别,分别在什么情况下使用_第4张图片
使用相等操作符(==)的写法明显更加简洁
所以,除了在比较对象属性为null或者undefined的情况下,可以使用相等操作符,其他情况一律使用全等操作符。

你可能感兴趣的:(javascript,开发语言,ecmascript)