Kit Cambridge指出isNaN()的一個問題:它會隱式的將它的參數轉換成數字,所以即便參數是個不能轉換成數字的字符串,它也會返回true(轉換成了NaN):
復制代碼 代碼如下:
> Number("xyz")
NaN
> isNaN("xyz")
true
由於相同的原因,isNaN對其他很多對象也返回true:
復制代碼 代碼如下:
> Number({})
NaN
> isNaN({})
true
> Number(["xzy"])
NaN
> isNaN(["xzy"])
true
重寫了valueOf方法的自定義對象同樣:
復制代碼 代碼如下:
> var obj = { valueOf: function () { return NaN } };
> Number(obj)
NaN
> isNaN(obj)
true
所以可以利用NaN是唯一一個滿足(x !== x)不等式的值來寫一個自己的isNaN函數,這樣就不會有上面提到的問題:
復制代碼 代碼如下:
function myIsNaN(x) {
return x !== x;
}
目前一個修正版的isNaN方法Number.isNaN()已經被添加到了ECMAScript 6中(譯者注:Firefox已經實現了).Crockford實現的這個方法,比上面的myIsNaN更容易理解,核心代碼是這樣的:
復制代碼 代碼如下:
Number.isNaN = function (value) {
return typeof value === 'number' && isNaN(value);
};
2.Infinity
用0作除數會產生另外一個特殊值Infinity:
復制代碼 代碼如下:
> 3/0
Infinity
你不能想當然的猜測正無窮大或者負無窮大的計算結果:
復制代碼 代碼如下:
>Infinity - Infinity
NaN
比無窮大還大的值仍然是無窮大:
復制代碼 代碼如下:
> Infinity + Infinity
Infinity> 5 * Infinity
Infinity
3.參考
What is {} + {} in JavaScript?