JS面试题:[1, 2, 3].map(parseInt)

[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,就代表字符串是用二进制表达的。如果我们省略第二个参数,当字符串以0x0X开头,它就会被当作十六进制,否则被当作十进制。
特殊情况:当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

你可能感兴趣的:(JS面试题:[1, 2, 3].map(parseInt))