JS中的`==`涉及的类型转换

JS中的==涉及的类型转换

  • 在JavaScript中用==对两个变量进行比较时,类型相同,primitive value的直接比较,object类型的则比较这两个变量是不是指向一个object。
var obj1 = {name: "John"};
var obj2 = obj1;
obj2 === obj1; //true
var obj3 = {name: "John"};
obj3 == obj1; //false, 两个对象是独立不同的对象,即使他们内容一样,但是存储位置的不同导致他们不同

所以同样的,array也是object,比较时原则同object。

var a = [1,2,3];
var b = [1,2,3];
a == b; //false;
  • 当类型不同时,会自动进行类型转换,转换原则如下:
image
转换原则

1. number类型最优先

  • 当类型之一为number,其它类型都转化成number类型比较。除了null和undefined永远不转换。
  • 特例是NaN, NaN的类型是number,但它与任何类型value比较时都是false,即使是它自己
NaN == NaN; //false

2. boolean与其它类型

  • 有一个类型为boolean,则boolean转化为number,另一个非boolean的类型也转换为number进行比较。
true == "1"; //true,布尔值转为数字,真为1,假为0;右侧字符串也转为数字
true == "true"; //false, 都转为数字,左边是1,右边的string转为数字,Number(string),结果是NaN

3. string与其它类型

  • 一个为string,另一个为object,则object转换为primitive value your (先toString,再valueOf)
A B
string Object,转换为原始值(toString)
Array object; array.toString();空数组的toString之后是空字符串。
String object; 原始值string,比如{"item"}转换后为"item"
Number object; 原始值string,比如{2}转换为"2"

注意String object和Number object都是object,虽然写作{"item"},但其实存储的时候依旧是以object的键值对形式存储的。

var a = new String("John");
console.log(a);
/*VM275:1 String {"John"}
0: "J"
1: "o"
2: "h"
3: "n"
length: 4
__proto__: String
[[PrimitiveValue]]: "John" 
*/

4. object

  • object只有与object比较时不需要类型转换,根据reference比较对应的对象即可;
  • object与其他类型比较时,都要转换为原始值。

5. 例子

0 == []; //true, 数字与对象比较,对象转为原始值数字类型, []toString之后为"",Number("")结果是0
[] == ""; //true
0 == "\n"; //true 转义字符\n新起一行转为数字是0,同样为0的转义字符还有\f,\t,\r
0 == "\b"; //false 转义字符\b退格转为数字是NaN。
example
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。