前言
在javascript中最有趣的數(shù)據(jù)莫過于NaN,對(duì)于大部分小猿們剛接觸到這個(gè)概念的時(shí)候表情應(yīng)該是這樣的。本篇博客就來給各位客官介紹下NaN的知識(shí)點(diǎn)。
### NaN的介紹
- 在很多語(yǔ)言中都有NaN,比如C語(yǔ)言中nan和R語(yǔ)言中NAN以及javascript中的NaN,雖然每一門語(yǔ)言的拼寫不一樣,但是他們表示的含義幾乎一致,NaN全稱 `not a number`,表示的是一個(gè)非數(shù)字。
- 在javascript中NaN代表的含義也是代表一個(gè)非數(shù)字,非數(shù)字的情況就太多:一段字符串,一個(gè)函數(shù),甚至是數(shù)組和對(duì)象,那么這個(gè)NaN到底屬于哪種數(shù)據(jù)類型呢?答案是NaN屬于數(shù)值類型(Number)。
- 納尼,不是剛剛說過`not a number`,怎么又說它屬于Number類型呢?
- 客官莫慌,容本猿給你狡辯狡辯,這里面我們要先搞清楚一個(gè)概念,就是數(shù)據(jù)類型Number
- Number(數(shù)值)是javascript中的一種數(shù)據(jù)類型,其中包含了各種數(shù)值情況:十進(jìn)制、八進(jìn)制、十六進(jìn)制等各種進(jìn)制,而我們正常的數(shù)字屬于Number(數(shù)值)類型的一個(gè)子集,不正常的數(shù)字也是Number的一個(gè)子集,而NaN就是不正常數(shù)字的一種情況。
- 請(qǐng)?jiān)试S我用抽象派的畫技來給客官展示
- 我猜你已經(jīng)差不多懂我的意思,總結(jié)起來就是一句話(中文的博大精深)
- - `NaN是數(shù)值類型,但不是一個(gè)正常的數(shù)字,是一個(gè)非數(shù)字,僅僅一字之差。`
### NaN的產(chǎn)生
這個(gè)NaN到底如何產(chǎn)生的,結(jié)合本猿開發(fā)和查找資料總結(jié)以下兩種情況
- 在其他類型轉(zhuǎn)換成數(shù)值類型時(shí)候(包含手動(dòng)轉(zhuǎn)換和自動(dòng)轉(zhuǎn)換)
- - - 手動(dòng)轉(zhuǎn)換
```js
var num = Number('千鋒')
console.log(num) // NaN
```
- - - 自動(dòng)轉(zhuǎn)換
```js
var num = '千鋒' * '大前端'
console.log(num) // NaN
```
- - - 我們以一種情景對(duì)話的方式模擬情景
- 在數(shù)值某些計(jì)算的時(shí)候
```js
var x = Math.sqrt(-1)
console.log(x)
```
- - - Math.sqrt()方法是用來求平方根,但是只有一個(gè)正數(shù)才有平方根,負(fù)數(shù)是沒有平方根的,針對(duì)于這樣的計(jì)算到底給什么結(jié)果呢,js給出的結(jié)果就是NaN
### NaN有趣的靈魂
- 既然介紹完了NaN,那我們聊點(diǎn)有趣的,本猿給客官們總結(jié)了兩點(diǎn)。
1. NaN和任何數(shù)的計(jì)算 `js`
```js
console.log(NaN+1) // NaN
console.log(NaN*1) // NaN
console.log(NaN/1) // NaN
// ...
```
- 經(jīng)過本猿的觀測(cè),任何一個(gè)數(shù)和NaN的計(jì)算,結(jié)果都是NaN,各位客官們是不是感受到了快樂
- NaN和任何數(shù)的比較
本猿針對(duì)于幾種可能會(huì)混淆情況比較,發(fā)現(xiàn)結(jié)果都是false
```js
console.log(NaN === 0) // false
console.log(NaN === '') // false
console.log(NaN === undefined) // false
console.log(NaN === null) // false
```
難道是我用了全等,抱著試一試態(tài)度我又換成了==,結(jié)果也是false
```js
console.log(NaN == 0) // false
console.log(NaN == '') // false
console.log(NaN == undefined) // false
console.log(NaN == null) // false
```
經(jīng)過我反復(fù)測(cè)試,得出的結(jié)果是NaN和任何數(shù)據(jù)比較的結(jié)果都是false,但是感覺好像還有什么遺漏
名偵探柯南上身的我發(fā)現(xiàn)還有一種情況沒有考慮
```js
console.log(NaN === NaN) // false
console.log(NaN == NaN) // false
```
- 徹底破防了,這個(gè)NaN竟然和自己都不相等,那么如何去判斷某個(gè)數(shù)據(jù)是不是NaN呢?
- 正當(dāng)我準(zhǔn)備給ECMASCript提出草案的時(shí)候,突然想到了之前NaN的黃金搭檔 `isNaN()` 方法,這個(gè)方法就是天生為了檢測(cè)NaN準(zhǔn)備的
```js
console.log(isNaN(NaN)) // true
```
### 總結(jié)
- 本篇主要給大家介紹下NaN的概念,希望各位猿猿們?cè)谌蘸箝_發(fā)中能夠正確使用NaN和成功避免NaN留下的坑點(diǎn),如有不足歡迎指正,謝謝。更多關(guān)于“web前端培訓(xùn)”的問題,歡迎咨詢千鋒教育在線名師。千鋒已有十余年的培訓(xùn)經(jīng)驗(yàn),課程大綱更科學(xué)更專業(yè),有針對(duì)零基礎(chǔ)的就業(yè)班,有針對(duì)想提升技術(shù)的提升班,高品質(zhì)課程助理你實(shí)現(xiàn)夢(mèng)想。