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