现象:
当使用Number时
let arr = ['1', '2', '3'];
let r = arr.map(Number);
console.log(r); // 1,2,3
改用parseInt的结果却出人意料:
let arr = ['1', '2', '3'];
let r = arr.map(parseInt);
console.log(r); // 1,NaN,NaN
原因
由于map()
接收的回调函数可以有3
个参数:callback(currentValue, index, array)
,通常我们仅需要第一个参数,而忽略了传入的后面两个参数。但是parseInt(string, radix)
没有忽略第二个参数,导致实际执行的函数分别是:
parseInt('1', 0); // 1, 按十进制转换
parseInt('2', 1); // NaN, 没有一进制
parseInt('3', 2); // NaN, 按二进制转换不允许出现3
可以改为r = arr.map(Number)
;,因为Number(value)
函数仅接收一个参数。