国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

通過面試題學(xué)前端(一)parseInt

Jokcy / 2195人閱讀

摘要:前言最近無意中發(fā)現(xiàn)了一道前端面試題一想,答案不是嘛。這只是前端題目中的一題,以后我還會總結(jié)更多的前端面試題的相關(guān)知識點,來學(xué)習(xí)前端的相關(guān)知識

前言

最近無意中發(fā)現(xiàn)了一道前端面試題:

[1, 2, 3].map(parseInt)

一想,答案不是 [1, 2, 3] 嘛。但在 chrome 控制臺下運行一下,返回的卻是 [1, NaN, NaN]

這是怎么回事呢?讓我們來看看 map()parseInt() 方法的詳細用法。

map

map(callback, [thisArg]) 方法:

接受一個回調(diào)函數(shù) callback,返回一個 新的數(shù)組

返回的數(shù)組的元素的值為調(diào)用 callback 函數(shù)所返回的值(原數(shù)組有幾個元素,就調(diào)用幾次 callback

callback 接受 3 個參數(shù):

currentValue:當(dāng)前正在處理的數(shù)組元素的值

index:當(dāng)前正在處理的數(shù)組元素的索引

arr:調(diào)用 map 方法的數(shù)組

map 方法一般用于對現(xiàn)有數(shù)組每一個元素進行相同邏輯的運算處理的場景。
例如平時我工作的時候,該方法用的最多的場景是 在 react 中通過 this.state 對象中的某個數(shù)組類型的屬性來渲染具有相同 html 結(jié)構(gòu)的 jsx

class example extends React.component {
  state = {
    personList: [
      {
        name: "張三",
        age: 18
      },
      {
        name: "李四",
        age: 19
      },
      {
        name: "王五",
        age: 20
      }
    ]
  }
  render() {
    return (
      
        {this.state.personList.map(person => {
          return 
姓名:{person.name} 年齡:{person.age}
})}
) } }
parseInt

parseInt(string, [radix]):解析一個 字符串(第一個參數(shù)),返回一個 10 進制的整數(shù)

string:被解析的字符串(前后空格會被忽略,若不是字符串,則轉(zhuǎn)換成字符串)

radix:指定 string(第一個參數(shù))的基數(shù)(2~36,即 2 進制 ~ 36進制),若不傳或傳 0,則 string(第一個參數(shù))10 進制 來解析

再來看 [1, 2, 3].map(parseInt)

parseInt 回調(diào)函數(shù)會被調(diào)用三次:

// arr 表示數(shù)組 [1, 2, 3]
// 第一次調(diào)用
parseInt(1, 0, arr) // 1

// 第二次調(diào)用
parseInt(2, 1, arr) // NaN

// 第三次調(diào)用
parseInt(3, 2, arr) // NaN

首先,每一次調(diào)用 parseInt 回調(diào)函數(shù),都會將 數(shù)字類型 轉(zhuǎn)換為 字符串類型
1 -> "1",2 -> "2",3 -> "3"

第一次調(diào)用時,因為 radix 為 0 ,所以 string 按照 10 進制 處理,返回 10 進制數(shù) 1

第二次調(diào)用時,因為 radix 為 1,不在 2~36 范圍,直接返回 NaN

第三次調(diào)用時,因為 radix 為 2(二進制),但 string"3",不屬于 二進制范圍,所以返回 NaN

所以:[1, 2, 3].map(parseInt) 返回的是 [1, NaN, NaN]

更多:parseFloat

[1, 2, 3].map(parseFloat) 返回的是 [1, 2, 3],因為 parseFloat(string) 只接受一個參數(shù) string

map() 文檔
parseInt() 文檔
parseFloat() 文檔

總結(jié)

由于自己對 parseInt 方法的不熟悉,加上沒有仔細分析該面試題,導(dǎo)致自己答錯該題。

這只是前端題目中的一題,以后我還會總結(jié)更多的前端面試題的相關(guān)知識點,來學(xué)習(xí)前端的相關(guān)知識!

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/96624.html

相關(guān)文章

  • 前端面試題(4)JavaScript

    摘要:變量聲明提升在中,函數(shù)聲明與變量聲明經(jīng)常被引擎隱式地提升到當(dāng)前作用域的頂部。對象的方法和屬性是在全局范圍內(nèi)有效的。未形成標(biāo)準(zhǔn),實現(xiàn)混亂。 前端面試題JavaScript(一) JavaScript的組成 JavaScript 由以下三部分組成: ECMAScript(核心):JavaScript 語言基礎(chǔ) DOM(文檔對象模型):規(guī)定了訪問HTML和XML的接口 BOM(瀏覽器對...

    1treeS 評論0 收藏0
  • 前端面試題(4)JavaScript

    摘要:變量聲明提升在中,函數(shù)聲明與變量聲明經(jīng)常被引擎隱式地提升到當(dāng)前作用域的頂部。對象的方法和屬性是在全局范圍內(nèi)有效的。未形成標(biāo)準(zhǔn),實現(xiàn)混亂。 前端面試題JavaScript(一) JavaScript的組成 JavaScript 由以下三部分組成: ECMAScript(核心):JavaScript 語言基礎(chǔ) DOM(文檔對象模型):規(guī)定了訪問HTML和XML的接口 BOM(瀏覽器對...

    spademan 評論0 收藏0
  • 前端面試題(4)JavaScript

    摘要:變量聲明提升在中,函數(shù)聲明與變量聲明經(jīng)常被引擎隱式地提升到當(dāng)前作用域的頂部。對象的方法和屬性是在全局范圍內(nèi)有效的。未形成標(biāo)準(zhǔn),實現(xiàn)混亂。 前端面試題JavaScript(一) JavaScript的組成 JavaScript 由以下三部分組成: ECMAScript(核心):JavaScript 語言基礎(chǔ) DOM(文檔對象模型):規(guī)定了訪問HTML和XML的接口 BOM(瀏覽器對...

    王晗 評論0 收藏0
  • 前端面試基本知識點——javascript

    摘要:又到一年春招季,們又要奔波于一場又一場的面試。今天就先來小小總結(jié)一下方面的知識點,方便你我他。在發(fā)送請求前加上。在后面加上時間搓。這樣頁面的所有都會執(zhí)行這條語句就是不需要保存緩存記錄。如何解決跨域問題服務(wù)器上設(shè)置代理頁面 又到一年春招季,coder們又要奔波于一場又一場的面試。今天就先來小小總結(jié)一下javascript方面的知識點,方便你我他。隨時補充 js基本數(shù)據(jù)類型 Undef...

    hankkin 評論0 收藏0
  • 前端面試總結(jié)二

    摘要:服務(wù)器無法理解請求的格式,客戶端不應(yīng)當(dāng)嘗試再次使用相同的內(nèi)容發(fā)起請求。服務(wù)器端暫時無法處理請求可能是過載或維護。 為什么要使用css預(yù)編譯 1、css無法遞歸式定義2、解決復(fù)用性不夠3、可以緩解瀏覽器兼容造成的冗余 cookie,sessionStorage和localStorage的區(qū)別 cookie用來在瀏覽器和服務(wù)器中傳遞并且總量很小sessionStorage和localSto...

    scwang90 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<