[1, 2, 3].map(parseInt)的结果是什么
显而易见的,在该题目中有两个JavaScript方法,一个是Array.prototype.map
,另一个是parseInt()
。
Array.prototype.map
首先是Array.prototype.map
方法,这是ES5给出的数组实例的方法。给map传入一个回调函数,map就会遍历数组,将相关信息一起传入回调函数,并取回这个回调函数的返回值作为新数组的对应索引的元素,并返回这个新数组。
回调函数每次可以拿到三个值——(1)数组元素(2)索引值(3)数组本身
[1, 2, 3].map((value, index, array)) => {
return value * 2
} // [2, 4, 6]
注:传递给map()的函数的调用方式和传递给forEach()的函数的调用方式一样,但传递给map()的函数应该要有返回值。map()返回的是新数组,它不修改调用数组。如果调用数组是稀疏数组,则返回的数组也是稀疏数组——具有相同的长度和相同的缺失元素。
Array.prototype.map方法的底层实现
Array.prototype.myMap = function(callbackfn) {
const arr = this
const retArr = new Array(arr.length)
for (let i = 0; i < arr.length; i++) {
retArr[i] = callbackfn(arr[i], i, arr)
}
return retArr
}
parseInt
parseInt函数的作用是将第一个字符串转换为数字,它接受两个参数,第一个参数是我们需要转换的字符串,第二个参数是可选的,它代表字符串的基数,即该参数表明我们需要通过几进制去对这个字符串完成转换,如2,就代表字符串是用二进制表达的。如果我们省略第二个参数,当字符串以0x
或0X
开头,它就会被当作十六进制,否则被当作十进制。
特殊情况:当parseInt的第二个参数为0时,相当于第二个参数没有传,字符串会被当成十进制,该情况也是最常用的情况。
此外,当字符串的第一个非空格字符无法转换成数字时,也会返回NaN。
下面给出一些例子:
parseInt('01', 2) // 1
parseInt('0xa') // 10
parseInt('123') // 123,常见用法
parseInt('3', 2) // NaN
回到题目
[1, 2, 3].map(parseInt)的parseInt
作为回调函数拿到了map提供的三个参数,得益于JavaScript是弱类型语言,所以传参数量不匹配也不会报错,只会把不用的参数抛弃掉,将缺少的参数设置为undefined。
这里的parseInt只用到了两个参数,分别是数组元素和索引值。
实际上我们可以把题目展开成如下函数:
const res = [1, 2, 3].map((item, index) => {
return parseInt(item, index)
})
如此便清晰明了了,我们很容易得到以下结果:
parseInt('1', 0)
// => 1 参数为0,等价于parseInt('1')
parseInt('2', 1)
// => NaN 参数为1,没有一进制这种东西
parseInt('3', 2)
// => NaN 参数为2,3无法用来表示二进制
所以最后我们得到返回结果:[1, NaN, NaN]
参考链接:
Web 前端陈年烂题:['1', '2', '3'].map(parseInt) 结果是什么? - 掘金 (juejin.cn)
解析 [1, 2, 3].map(parseInt)【JS面试题】_哔哩哔哩_bilibili