中的回调函数
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。开头,则猜测为十六进制。)
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)