在JavaScript中什么情况下使用==是正确的?简而言之:没有。这篇文章来看五种情况下总是使用===,并且解释为什么不用==。
JavaScript有两种操作符用来比较两个值是否相等 [1]:
给JavaScript初学者的建议是完全忘掉 == ,并且总是使用 ===。事实证明,后者是更符合常规的。有五种案例,表面看起来可以不遵从规则,但真的不是这样。从现在开始,我使用下面的规则:
意图清晰的代码胜过更简洁的代码。 记住:你的代码仅写一次,但被阅读很多次——尽可能保证对阅读者友好。
例如,使用typeof操作符[2],你能确保结果是字符串。然后可以放心使用 ==,因为我们确定不会在发生类型转换。
1 if (typeof x == "function") { 2 ... 3 }
然而,有两个反对这样做的原因:
当使用 == 时,undefined和null在结果上等价——他们彼此相等,互相相等,但没有意义(包括JavaScript中的能被转换为false的值):
1 > null == null 2 true 3 > undefined == null 4 true 5 > false == null 6 false 7 > 0 == null 8 false
因此,下面的if语句检测的是null或undefined。
1 if (x == null) { 2 ... 3 }
然而,这是否出于简洁性考虑,意图并不清晰:如果你同时也检测undefined,那么你可以这样写。然而,如果JavaScript初学者读到你的代码,他们可能认为你仅仅检测null。如果高手读到你的代码,他们可能认为你写错了,并且应该写成 ===。
1 if (x === undefined || x === null) { 2 ... 3 }
如果你有点懒的话,上面的代码能被精简为:
1 if (!x) { 2 ... 3 }
和上面一样的警告:这条件成立,如果x有否定类型的值。
1 undefined 2 null 3 false 4 0 5 ""
场景:你正工作在用户界面代码或编码处理服务器端参数。你可能会把数字编码为字符串。如果x是一个字符串,你可以像下面这样比较:
1 if (x == 123) { 2 ... 3 }
但问什么不告诉其他阅读你代码的人,如果x不是数字,它将被转换为数字?
1 if (Number(x) === 123) { 2 ... 3 }
使用 == 时你可以将一个原始值和其他原始值或包装类型 [4]实例做比较:
1 > function isAbc(x) { return x == "abc" } 2 > isAbc("abc") 3 true 4 > isAbc(new String("abc")) 5 true
而使用 === 时,你不能这样做:
1 > new String("abc") === "abc" 2 false
左边是一个对象而右边是原始值。因为他们类型不同所以不严格相等。然而,你同样需要向阅读你代码的人解释清楚你的意图。下面是表达式:
1 x =="abc"
你的目的是什么?
String(x) ===
"abc"
x.valueOf()
=== "abc"
理由是这样的:我想我的代码像JavaScript一样灵活。== 操作符帮我实现这一目的。例如JavaScript的灵活体现在它自动转换值类型:
1 > "abc" + false 2 ‘abcfalse‘ 3 > 3 + true 4 4 5 > +"73" 6 73
有几个理由反驳上述假说:
1.即使会自动转换但并不总是按你需要的方式转换。例如:
1 > !"false" 2 false 3 > 7 + "3" 4 ‘73‘ 5 > Number("") 6 0
2.非严格相等的转换规则非常复杂:
1 > 2 == false 2 false 3 > 2 == true 4 false 5 > Boolean(2) 6 true
3.显示转化加上严格相等的代码更具描述性。比较:灵活的非严格相等。
1 function is123Implicit(x) { 2 return x == 123; 3 } 4 > is123Implicit(123) 5 true 6 > is123Implicit(new Number(123)) 7 true 8 > is123Implicit("123") 9 true
替代方案:灵活的显式转换和严格相等。
1 function is123Explicit(x) { 2 x = Number(x); 3 return x === 123; 4 } 5 > is123Explicit(123) 6 true 7 > is123Explicit(new Number(123)) 8 true 9 > is123Explicit("123") 10 true
4.有人说您的代码缺少灵活性?可以说JavaScript的默认灵活性利大于弊(对于学习难度而言)。写防御型的代码更容易暴漏Bug。is123Explicit()
的防御型版本看起来像下面这样:
function is123Defensive(x) { if (typeof x !== "number") { throw new TypeError("Not a number: "+x); } return x === 123; }
如果你想给函数传递任何非原始数字值,你必须先进行类型转换。
我希望我让你确信坚持简单的规则——”不用 ==“的意义,不只是对新手。在你的代码中魔法越少,通常意味着越容易理解。
在JavaScript中什么时候使用==是正确的?,布布扣,bubuko.com
原文:http://www.cnblogs.com/yiliweichinasoft/p/3710579.html