==、===、isNaN、Object.is的比较

1、==

等同,比较运算符,两边值类型不同的时候,先进行类型转换,再比较;

  • 如果两个值具有相同的类型,那么就检测它们的等同性。如果这两个值完全相同,它们就相等。如果它们不完全相同,则它们不相等。
  • 如果两个值的类型不同,它们仍然可能相等。用下面的规则和类型转换来检测它们的相等性 ◦如果一个值是null,另一个值是undefined,它们相等。
  • 如果一个值是数字,另一个值是字符串,把字符串转换为数字,再用转换后的值进行比较。
  • 如果一个值为true,将它转化为1,再进行比较。如果一个值为false,把它转化为0,再进行比较。
  • 如果一个值是对象,另一个值是数字或字符串,将对象转换成原始类型的值,再进行比较。
console.log([123]==123);//true    
    console.log({}=={});    //false
    console.log(null==null);//true
    console.log(null==undefined);//true
    console.log(false==0);//true
    console.log(true==1);//true
    console.log(NaN==NaN);//false
    console.log(0/NaN==0/NaN);//false
    console.log(0/0==0/0);//false

 

2、===

恒等,严格比较运算符,不做类型转换,类型不同就是不等;

  • 如果两个值的类型不同,它们就不相同。
  • 如果两个值是数字,而且值相同,那么除非其中一个或两个都是NaN(这种情况它们不是等同的),否则它们是等同的。值NaN永远不会与其他任何值等同,包括它自身(奇怪的家伙)
  • 如果两个值都是字符串,而且在字符串中同一位置上的字符完全相同,那么它们就完全等同。如果字符串的长度或内容不同,它们就不是等同的。
  • 如果两个值都是布尔型true,或者两个值都是布尔型false,那么它们等同。
  • 如果两个值引用的是同一个对象、数组或函数,那么它们完全等同。如果它们引用的是不同的对象(数组或函数),它们就不完全等同,即使这两个对象具有完全相同的属性,或两个数组具有完全相同的元素。
  • 如果两个值都是null或都是undefined,它们完全相同。
console.log([123]===123);//false
    console.log({}==={});//false
    console.log(null===null);//true
    console.log(null===undefined);//false
    console.log(false===0);//false
    console.log(true===1);//false
    console.log(NaN===NaN);//false
    console.log(0/NaN===0/NaN);//false
    console.log(0/0===0/0);//false

3、isNaN

是之前用来判断一个数据是否是NaN的方法,但是有很严重的缺陷。NaN表示not a number,即不是数字。所有经过Number()方法转换得到NaN的数据,用isNaN来判断结果都是true。

isNaN(NaN);       // true
isNaN(undefined); // true
isNaN({});        // true

isNaN(true);      // false
isNaN(null);      // false
isNaN(37);        // false

// strings
isNaN("37");      // false: 可以被转换成数值37
isNaN("37.37");   // false: 可以被转换成数值37.37
isNaN("");        // false: 空字符串被转换成0
isNaN(" ");       // false: 包含空格的字符串被转换成0

// dates
isNaN(new Date());                // false
isNaN(new Date().toString());     // true

isNaN("blabla")   // true: "blabla"不能转换成数值

那么,如何准确的判断一个数据是否是NaN呢?

NaN有一个特点,NaN不等于自身,所以可以用这样的方式来判断:

function dataisNaN(a){
    return a!==a && isNaN(a);
}

4、Object.is()
Object.is()是es6引入的、用于判断两个或者多个数据是否全等的方法。其行为与===基本一致,不过有两处不同:

  1. +0不等于-0
  2. NaN等于自身。
+0 === -0 //true
NaN === NaN // false

Object.is(+0, -0) // false
Object.is(NaN, NaN) // true

 

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值