Web 前端陈年烂题:['1', '2', '3'].map(parseInt) 结果是什么?

简介: 前端西瓜哥

大家好,我是前端西瓜哥,本文讲的是一道比较经典的前端面试题,本文将会深入分析此题,深挖知识点,让你完全掌握此题的解法。

这是道 Web 前端的陈年烂题,烂是烂,但我就是要说,高考也是年年有呢。此题考察的是对 JavaScript 方法的熟悉程度。

不直接给出答案,我们先看看思路。

Array.prototype.map

首先是 Array.prototype.map 方法,这是数组实例的方法。给 map 传入一个回调函数,map 就会遍历数组元素,将相关信息一起传入回调函数,并取这个回调函数的返回值作为新数组的对应索引的元素,并将这个新数组返回。

回调函数每次可以拿到的当前迭代的(1)数组元素(2)索引值(3)以及数组本身。

[1,2,3].map((value, index, array) => {
  return value * 2;
})
// 返回 [2, 4, 6]
复制代码

如果你是初学者,可能会对这个黑盒底层是怎么实现有些疑惑,我就顺手实现一下 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

Array.prototype.map 方法其实还算简单,parseInt 则要复杂得多的多了。

parseInt 函数的作用是将一个字符串转换为数字。

parseInt(string [, radix]) 接受两个参数,第一个参数是我们需要转换的字符串。第二个参数是字符串的基数 radix,比如是 2 的话,就代表字符串是用二进制表达的。需要特别注意的是,第二个参数是可选的。

第二个参数如果省略,情况会变得复杂。如果字符串以 0x0X 开头,它就会当作十六进制,否则被当作十进制。

下面说一些例子:

parseInt('10', 2);
// => 2。(1 * 2 + 0 * 1)
parseInt('0xa');
// => 10。被当作十六进制,等价于 parseInt('a', 16)
parseInt('123');
// => 123。被当作十进制,最常见的用法,
复制代码

理论上基数 radix 应该为大于等于 2,小于等于 36 的数字,否则会被当作不合法,返回 NaN。但有一个值除外,那就是 0。

当 parseInt 的第二个参数 radix 为 0 时,parseInt 会当作第二个参数没有传,所以字符串会被当成十进制。

此外当字符串第一个非空格字符不能转换为数字时,也会返回 NaN。

回到本题

['1', '2', '3'].map(parseInt)的 parseInt 作为回调函数拿到了 map 提供的三个参数,得益于 JavaScript 是非常方便的弱类型语言,所以传参数量不匹配也不会报错的,只会把不用的参数抛弃掉,缺少的参数设置为 undefined。

这里 parsetInt 只用到两个参数,分别是 数组元素索引值。也就是:

parseInt('1', 0);
// 1    特殊情况,等价于parseInt('1')
parseInt('2', 1);
// NaN  没有一进制这种东西
parseInt('3', 2);
// NaN  没能找到合法字符,虽然 3 是数字,但它无法用来表达二进制,二进制只能为 0 和 1。
复制代码

所以返回结果为:[1, NaN, NaN]

相关文章
|
1天前
|
存储 前端开发 API
ES6的Set和Map你都知道吗?一文了解集合和字典在前端中的应用
该文章详细介绍了ES6中Set和Map数据结构的特性和使用方法,并探讨了它们在前端开发中的具体应用,包括如何利用这些数据结构来解决常见的编程问题。
ES6的Set和Map你都知道吗?一文了解集合和字典在前端中的应用
|
1天前
|
存储 前端开发 JavaScript
浅谈Web前端安全策略xss和csrf,及又该如何预防?
该文章详细讨论了Web前端安全中的XSS(跨站脚本攻击)和CSRF(跨站请求伪造)攻击原理及其防范措施,帮助读者了解如何保护Web应用程序免受这两种常见安全威胁的影响。
浅谈Web前端安全策略xss和csrf,及又该如何预防?
|
1天前
|
XML 缓存 JavaScript
提升对前端的认知,不得不了解Web API的DOM和BOM
该文章强调了在前端开发中理解和掌握DOM(文档对象模型)和BOM(浏览器对象模型)的重要性,并介绍了它们的相关操作和应用。
提升对前端的认知,不得不了解Web API的DOM和BOM
|
16天前
|
前端开发
【前端web入门第五天】03 清除默认样式与外边距问题【附综合案例产品卡片与新闻列表】
本文档详细介绍了CSS中清除默认样式的方法,包括清除内外边距、列表项目符号等;探讨了外边距的合并与塌陷问题及其解决策略;讲解了行内元素垂直边距的处理技巧;并介绍了圆角与盒子阴影效果的实现方法。最后通过产品卡片和新闻列表两个综合案例,展示了所学知识的实际应用。
28 11
|
9天前
|
编解码 前端开发 JavaScript
web端 本地调用摄像头、前端摄像头
web端 本地调用摄像头、前端摄像头
|
16天前
|
前端开发
|
16天前
|
弹性计算 前端开发 容器
【前端web入门第六天】02 flex布局
Flex布局是一种现代CSS布局模式,通过给父元素设置`display: flex`,其子元素可自动挤压或拉伸。它包含弹性容器和弹性盒子,主轴默认为水平方向,侧轴为垂直方向。主轴对齐方式由`justify-content`属性控制,侧轴对齐方式包括`align-items`(针对所有子元素)和`align-self`(针对单个子元素)。修改主轴方向使用`flex-direction`属性,`flex`属性用于控制子元素在主轴上的伸缩比例。此外,`flex-wrap`属性允许子元素换行,而`align-content`属性则定义多行对齐方式。
|
16天前
|
前端开发
【前端web入门第五天】02 盒子模型基础
本文档详细介绍了CSS中的盒子模型及其组成部分,包括内容区域、内边距、边框线和外边距。通过具体示例展示了如何设置边框线、内边距及外边距,并解释了尺寸计算方法和版心居中的技巧。内容丰富,示例清晰,有助于理解盒子模型在网页布局中的应用。
|
16天前
|
前端开发
【前端web入门第六天】01 CSS浮动
这是关于CSS布局第六天学习目标的介绍,主要解决多个`&lt;div&gt;`标签在同一行显示的问题,即一个在左边,另一个在右边。文中介绍了标准流、浮动及flex布局的概念,重点推荐使用flex布局。文章详细讲解了浮动的基本使用、布局技巧及清除浮动的方法,包括额外标签法、单伪元素法、双伪元素法和`overflow`隐藏法,并提供了示例代码帮助理解。
|
2天前
|
Go 定位技术 索引
Go 语言Map(集合) | 19
Go 语言Map(集合) | 19