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

为什么parseInt用Array#map产生NaN?,第1张

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

中的回调函数

Array.map
具有 三个 参数

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

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

因此,如果调用

parseInt
实际上需要 两个 参数的函数,则第二个参数将是元素的索引。

在这种情况下,您最终

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

parseInt('1', 0); // OK - gives 1parseInt('2', 1); // FAIL - 1 isn't a legal radixparseInt('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
。开头,则猜测为十六进制。)



欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5509128.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-13
下一篇 2022-12-13

发表评论

登录后才能评论

评论列表(0条)

保存