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

如题所述

第1个回答  2022-06-20

显而易见的,在该题目中有两个JavaScript方法,一个是 Array.prototype.map ,另一个是 parseInt() 。

首先是 Array.prototype.map 方法,这是ES5给出的数组实例的方法。给map传入一个回调函数,map就会遍历数组,将相关信息一起传入回调函数,并取回这个回调函数的返回值作为新数组的对应索引的元素,并返回这个新数组。
回调函数每次可以拿到三个值——(1)数组元素(2)索引值(3)数组本身

注:传递给map()的函数的调用方式和传递给forEach()的函数的调用方式一样,但传递给map()的函数应该要有返回值。map()返回的是新数组,它不修改调用数组。如果调用数组是稀疏数组,则返回的数组也是稀疏数组——具有相同的长度和相同的缺失元素。
Array.prototype.map方法的底层实现

parseInt函数的作用是将第一个字符串转换为数字,它接受两个参数,第一个参数是我们需要转换的字符串,第二个参数是可选的,它代表字符串的基数,即该参数表明我们需要通过几进制去对这个字符串完成转换,如2,就代表字符串是用二进制表达的。如果我们省略第二个参数,当字符串以 0x 或 0X 开头,它就会被当作十六进制,否则被当作十进制。
特殊情况:当parseInt的第二个参数为0时,相当于第二个参数没有传,字符串会被当成十进制,该情况也是最常用的情况。
此外,当字符串的第一个非空格字符无法转换成数字时,也会返回NaN。
下面给出一些例子:

[1, 2, 3].map(parseInt)的parseInt 作为回调函数拿到了map提供的三个参数,得益于JavaScript是弱类型语言,所以传参数量不匹配也不会报错,只会把不用的参数抛弃掉,将缺少的参数设置为undefined。
这里的parseInt只用到了两个参数,分别是 数组元素 索引值
实际上我们可以把题目展开成如下函数:

如此便清晰明了了,我们很容易得到以下结果:

所以最后我们得到返回结果: [1, NaN, NaN]