['1', '2', '3'].map(parseInt) what & why ?

这个题,首先要考虑两个问题:
一、parseInt的函数的签名
二、map的函数签名,而后再考虑这两个函数在一块儿使用的时候,会有什么结果数组

parseInt

parseInt() 函数解析一个字符串参数,并返回一个指定基数的整数 (数学系统的基础)。浏览器

parseInt(param, radix) 至关于 parseInt(String(param).trim(), radix)函数

const value = parseInt(string[, radix]);
复制代码

其中 string是一个要解析的字符串,若是不是字符串,则使用toString()方法给转换成string,开头的空格会被忽略。ui

radix是一个介于2-36的整数。表示一个基数,要将字符串转换成这个基数的进制。默认是10。this

返回值是一个整数或者NaN。spa

parseInt(100) // 100
    parseInt(100, 10) //100
    parseInt(100, 2) // 4 由于100先转成了'100',而后在2进制下,100就是4。
复制代码

注意:code

在radix为 undefined,或者radix为 0 或者没有指定的状况下,JavaScript 做以下处理:索引

  • 若是字符串 string 以"0x"或者"0X"开头, 则基数是16 (16进制).
  • 若是字符串 string 以"0"开头, 基数是8(八进制)或者10(十进制),那么具体是哪一个基数由实现环境决定。ECMAScript 5 规定使用10,可是并非全部的浏览器都遵循这个规定。所以,永远都要明确给出radix参数的值。
  • 若是字符串 string 以其它任何值开头,则基数是10 (十进制)。

radix 为1或radix > 36时,返回值默认为NaNip

map

map()方法建立一个新数组,其结果是该数组中的每一个元素都调用一个提供的函数后返回的结果。element

const new_array = arr.map(function callback(currentValue[,index[, array]]) {
     // Return element for new_array
     }[, thisArg])
复制代码

能够看到callback回调函数须要三个参数, 咱们一般只使用第一个参数 (其余两个参数是可选的)。

  • currentValue 是callback 数组中正在处理的当前元素。

  • index可选, 是callback 数组中正在处理的当前元素的索引。

  • array可选, 是callback map 方法被调用的数组。

  • 另外还有thisArg可选, 执行 callback 函数时使用的this 值。

    const arr = [1, 2, 3]; arr.map((num) => num + 1); // [2, 3, 4]

了解了这两个函数的签名,咱们再来看这个题目:

['1', '2', '3'].map(parseInt) 
复制代码

这意味着,每一个map的迭代,都要给parseInt传递两个参数,item和index,就是字符串和基数。

那这个表达式能够写成

['1', '2', '3'].map((item, index) => parseInt(item, index))
复制代码

返回的结果应该是:

parseInt('1', 0) // 1 
    parseInt('2', 1) // NaN
    parseInt('3', 2) // NaN 由于3不是2进制里的数,因此就报错。
复制代码

因此该表达式返回的数组为:

['1', '2', '3'].map(parseInt)
    // [1, NaN, NaN]
复制代码

加里·伯恩哈德例子也就很好解释了,这里再也不赘述

['10','10','10','10','10'].map(parseInt);
    // [10, NaN, 2, 3, 4]
复制代码
相关文章
相关标签/搜索