js “==“与“===“的区别

1. == 与 === 的区别

== 会先进行类型转换,再确定操作数是否相等。
=== 只有在两操作数不转换的前提下相等才返回true。

2. ==的使用

(1)转换操作数时,遵循如下规则:

  • 若任一操作数是布尔值,则将其转换为数值再比较是否相等。false➡0,true➡1。
  • 若一个操作数是字符串,另一个操作数是数值,则尝试将字符串转换为数值,再比较是否相等。

字符串转换数值的规则:

  • 字符串包含数值字符(包含数值字符前带加、减号的情况),转换伪一个十进制数值
  • 字符串包含有效的浮点数格式如"1.1",转换为相应浮点值
  • 字符串包含有效的十六进制格式如"0xf",则会转换为与该十六进制对应的十进制整数
  • 空字符串(不包含字符),则返回0
  • 其他情况,返回NaN
  • 若一个操作数是对象,另一个操作数不是,则调用对象的valueOf()方法取得其原始值,再根据前面的规则比较。

(2)进行比较时,遵循如下规则:

  • null和undefined相等。
  • null和undefined不能转换为其他类型的值再比较。
  • 有任一操作数是NaN, == 返回false,!= 返回true。注意:NaN不等于NaN;
  • 若两个操作符都是对象,则比较他们是不是同一个对象。若两者指向同一个对象,则 == 返回true,否则,两者不相等。

一些例子:

表达式结果
null == undefinedtrue
“NaN” == NaNfalse
5 == NaNfalse
NaN == NaNfalse
NaN != NaNtrue
false == 0true
true == 1true
true == 2false
undefined == 0false
null == 0false
“5” == 5true

注:NaN是number类型的。

2. 判断以下哪些表达式为真值

(1)

console.log(null == 0);
console.log(undefined == "0");
console.log([] == []);
console.log([] == false);
console.log(NaN == false);
console.log(null == undefined);

答案:

false
false
false
true
false
true

注意:对于[] == false,存在object,左边先转化为原始值" ",于是左边为string, 右边为boolean,两者转为number后都为0
(2)

console.log(null === null);
console.log(NaN === NaN);
console.log(undefined === undefined);

运行结果:

true
false
true
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值