您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

为什么parseInt用Array#map产生NaN?

为什么parseInt用Array#map产生NaN?

中的回调函数Array.map具有 三个 参数:

在您链接到的同一Mozilla页面上:

回调使用三个参数来调用:元素的值,元素的索引和要遍历的Array对象。”

因此,如果调用parseInt实际上需要 两个 参数的函数,则第二个参数将是元素的索引。

在这种情况下,您最终parseInt依次调用基数0、1和2。第一个与不提供参数相同,因此认基于输入(在本例中为10)。以1为底的数字是不可能的,以3为底的数字不是有效数字:

parseInt('1', 0); // OK - gives 1
parseInt('2', 1); // FAIL - 1 isn't a legal radix
parseInt('3', 2); // FAIL - 3 isn't legal in base 2

因此,在这种情况下,您需要包装函数

['1','2','3'].map(function(num) { return parseInt(num, 10); });

或使用ES2015 +语法:

['1','2','3'].map(num => parseInt(num, 10));

(在两种情况下,最好如图所示显式提供一个基数parseInt,因为否则它会根据输入来猜测基数。在某些较旧的浏览器中,前导0会导致它猜测八进制,这往往是有问题的。它仍然会如果字符串以0x。开头,则猜测为十六进制。)

其他 2022/1/1 18:20:12 有496人围观

撰写回答


你尚未登录,登录后可以

和开发者交流问题的细节

关注并接收问题和回答的更新提醒

参与内容的编辑和改进,让解决方法与时俱进

请先登录

推荐问题


联系我
置顶