成人免费观看网欧美片-成人免费观看视频-成人免费观看男女羞羞视频-成人免费观看的视频黄页-成人免费高清视频-成人免费福利片在线观看

千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機構(gòu)

手機站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時隨地免費學(xué)

千鋒教育

掃一掃進入千鋒手機站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時隨地免費學(xué)習(xí)課程

當前位置:首頁  >  技術(shù)干貨  > 趣談JavaScript中NaN

趣談JavaScript中NaN

來源:千鋒教育
發(fā)布人:wjy
時間: 2022-06-02 13:44:00 1654148640

前言

在javascript中最有趣的數(shù)據(jù)莫過于NaN,對于大部分小猿們剛接觸到這個概念的時候表情應(yīng)該是這樣的。本篇博客就來給各位客官介紹下NaN的知識點。

JavaScript中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ù)字的一種情況。
- 請允許我用抽象派的畫技來給客官展示

3

- 我猜你已經(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
```

- - - 我們以一種情景對話的方式模擬情景

4

- 在數(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)過我反復(fù)測試,得出的結(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前端培訓(xùn)”的問題,歡迎咨詢千鋒教育在線名師。千鋒已有十余年的培訓(xùn)經(jīng)驗,課程大綱更科學(xué)更專業(yè),有針對零基礎(chǔ)的就業(yè)班,有針對想提升技術(shù)的提升班,高品質(zhì)課程助理你實現(xiàn)夢想。

tags:
聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強師集結(jié),手把手帶你蛻變精英
請您保持通訊暢通,專屬學(xué)習(xí)老師24小時內(nèi)將與您1V1溝通
免費領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT