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;
- 当类型不同时,会自动进行类型转换,转换原则如下:
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。