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

JavaScript07

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

显而易见的,在该题目中有两个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]

1.JavaScript 的对象(Object),本质上是键值对的集合(Hash结构),但是传统上只能用字符串当作键。这给它的使用带来了很大的限制。

2.类似于对象,也是键值对的集合,但是“键”的范围不限于字符串,各种类型的值(包括对象)都可以当作键。也就是说,Object结构提供了“字符串—值”的对应,Map 结构提供了“值—值”的对应,是一种更完善的 Hash 结构实现。

3.如果对同一个键多次赋值,后面的值将覆盖前面的值。

4.只有对同一个对象的引用,Map 结构才将其视为同一个键。Map 的键实际上是跟内存地址绑定的,只要内存地址不一样,就视为两个键。这就解决了同名属性碰撞(clash)的问题。

5.如果 Map 的键是一个简单类型的值(数字、字符串、布尔值),则只要两个值严格相等,Map 将其视为一个键.

[].map()基本用法跟forEach方法类似:

array.map(callback,[ thisObject])

map方法的作用不难理解,“映射”嘛,也就是原数组被“映射”成对应新数组。下面这个例子是数值项求平方:

可用于数组转换,将数组转换成对象数组