这个题,首先要考虑两个问题:
一、parseInt的函数的签名
二、map的函数签名,而后再考虑这两个函数在一块儿使用的时候,会有什么结果数组
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 做以下处理:索引
radix 为1或radix > 36时,返回值默认为NaN。ip
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]
复制代码