`

JS ==和===运算符的比较

阅读更多

等价运算符「==」 和严密等价运算符「===」之间的比较。    [源自网络]

 

一:「==」与「===」共通之处

2个运算符都是用来进行比较的。相同的情况下true,不同的情况下false。比较对象的类型不同,而有所差别。

  1. 比较对象是数值or boolean,是根据值来比较的。
  2. 比较对象是字符串,是根据字符串的长度,构成等来比较。
  3. 比较对象是对象,数值,函数,是根据比较对象的参照(reference)是否一致。参照不同,就算值一致,也是false。

二:「==」与「===」不共通之处

2者不同之处在于,比较的时候,是否自动变换后比较。「==」自动变换。而「===」不变换,所以被称为严密的等价运算符。

 

试看下面的例子:

// 数值,boolean
alert(1 == true);// true
alert(0 == false);// true
alert(1 === true);// false
alert(0 === false);// false
 
// 数值,字符串
var a = 10;
var b = "10";
alert(a == b);// true
alert(a === b);// false
 
// 对象
var a = [1,2,3];
var b = a;
alert(a == b);// true
alert(a == [1,2,3]);// false
 
// 字符串,字符串对象
var a = "abc";
var b = new String("abc");
alert(a == b);// true
alert(a === b);// false
 

 

小结:

在进行比较时,对类型不在意,使用「==」。需要严格区别类型时,使用「===」。

 

 

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics