JavaScript NaN和Infinity特殊值 [譯]
在JavaScript中,NaN代表了“not a number”.主要在解析字符串出現(xiàn)錯(cuò)誤時(shí)會(huì)返回這個(gè)值:
> Number("xyz")
NaNNaN
的名字是“not a number”,不過也可以說是not not a number:
> NaN !== NaN
true
它是一個(gè)數(shù)字!類型為"number"
> typeof NaN
'number'
1.1 檢測NaN
JavaScript中,NaN是惟一一個(gè)和自己也不想等的值.所以,也就不能使用等號(hào)運(yùn)算符來判斷一個(gè)值是否是NaN,不過有全局函數(shù)isNaN()來干這件事.
> isNaN(NaN)
true
Kit Cambridge指出isNaN()的一個(gè)問題:它會(huì)隱式的將它的參數(shù)轉(zhuǎn)換成數(shù)字,所以即便參數(shù)是個(gè)不能轉(zhuǎn)換成數(shù)字的字符串,它也會(huì)返回true(轉(zhuǎn)換成了NaN):
> Number("xyz")
NaN
> isNaN("xyz")
true
由于相同的原因,isNaN對(duì)其他很多對(duì)象也返回true:
> Number({})
NaN
> isNaN({})
true
> Number(["xzy"])
NaN
> isNaN(["xzy"])
true
重寫了valueOf方法的自定義對(duì)象同樣:
> var obj = { valueOf: function () { return NaN } };
> Number(obj)
NaN
> isNaN(obj)
true
所以可以利用NaN是唯一一個(gè)滿足(x !== x)不等式的值來寫一個(gè)自己的isNaN函數(shù),這樣就不會(huì)有上面提到的問題:
function myIsNaN(x) {
return x !== x;
}
目前一個(gè)修正版的isNaN方法Number.isNaN()已經(jīng)被添加到了ECMAScript 6中(譯者注:Firefox已經(jīng)實(shí)現(xiàn)了).Crockford實(shí)現(xiàn)的這個(gè)方法,比上面的myIsNaN更容易理解,核心代碼是這樣的:
Number.isNaN = function (value) {
return typeof value === 'number' && isNaN(value);
};
2.Infinity
用0作除數(shù)會(huì)產(chǎn)生另外一個(gè)特殊值Infinity:
> 3/0
Infinity
你不能想當(dāng)然的猜測正無窮大或者負(fù)無窮大的計(jì)算結(jié)果:
>Infinity - Infinity
NaN
比無窮大還大的值仍然是無窮大:
> Infinity + Infinity
Infinity> 5 * Infinity
Infinity
3.參考
What is {} + {} in JavaScript?
相關(guān)文章
JS的遞增/遞減運(yùn)算符和帶操作的賦值運(yùn)算符的等價(jià)式
JS的遞增/遞減運(yùn)算符和帶操作的賦值運(yùn)算符的等價(jià)式...2007-12-12js根據(jù)需要計(jì)算數(shù)組中重復(fù)出現(xiàn)某個(gè)元素的個(gè)數(shù)
今天小編就為大家分享一篇關(guān)于js根據(jù)需要計(jì)算數(shù)組中重復(fù)出現(xiàn)某個(gè)元素的個(gè)數(shù),小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧2019-01-01純JS實(shí)現(xiàn)動(dòng)態(tài)時(shí)間顯示代碼
本篇文章主要是對(duì)純JS實(shí)現(xiàn)動(dòng)態(tài)時(shí)間顯示的代碼進(jìn)行了介紹,需要的朋友可以過來參考下,希望對(duì)大家有所幫助2014-02-02IE中JS跳轉(zhuǎn)丟失referrer問題的2個(gè)解決方法
這篇文章主要介紹了IE中JS跳轉(zhuǎn)丟失referrer問題的2個(gè)解決方法,算是IE的一個(gè)BUG吧,本文提供了2個(gè)方法解決這個(gè)問題,需要的朋友可以參考下2014-07-07HTML5+Canvas調(diào)用手機(jī)拍照功能實(shí)現(xiàn)圖片上傳(下)
這篇文章主要為大家詳細(xì)介紹了HTML5+Canvas調(diào)用手機(jī)拍照功能實(shí)現(xiàn)圖片上傳,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-04-04