廖雪峰老师的js中有这样一个例子:小明希望利用map()把字符串变成整数,他写的代码很简洁:
'use strict';
var arr = ['1', '2', '3'];
var r;
r = arr.map(parseInt);
console.log(r);
结果竟然是1, NaN, NaN,小明百思不得其解,请帮他找到原因并修正代码。
按照常理来说,map将函数对象作为其参数,迭代遍历数组的每个元素,并为每个元素调用一次函数,将元素值作为参数传递。这些函数调用的结果累积到一个新数组中。parseInt是内置函数,它尝试将字符串解析为数字并返回,如果无法解析为数字则返回NaN。所以上述例子应该显示1,2,3。那么问题出在哪?
根据map文档可知,map()语法:
var new_array = arr.map(function callback(currentValue[, index[, array]]) {
// Return element for new_array
}[, thisArg])
callback:产生新数组元素的函数,带有三个参数:currentValue、index和array
所以,所以例子中的parseInt函数应该是:parseInt(“1”,0,arr)、parseInt(“2”,1,arr)、parseInt(“3”,2,arr)。
那么我们再来看看parseInt这个内置函数,根据parseInt文档,parseInt(语法):
parseInt (string , radix)
parseInt函数根据指定的基数radix生成一个整数值,该值由字符串参数string的内容解释决定。字符串中的前导空格被忽略。如果基数未定义或为0,则默认是10。
例如:parseInt(‘1’)、parseInt(‘1’,0)以及parseInt(‘1’,10),结果都是1。
同理:parseInt(‘ABCD’,16)结果为43981,而parseInt(‘ABCD’,8)结果为NaN
由此可见:
由于parseInt中只需要两个参数,parseInt(“1”,0,arr)、parseInt(“2”,1,arr)、parseInt(“3”,2,arr)实为parseInt(“1”,0)、parseInt(“2”,1)、parseInt(“3”,2)。只有parseInt(“1”,0)是能够被正确解析的,结果为1,parseInt(“2”,1)、parseInt(“3”,2)不能被正确解析,结果为NaN。
修改例子:
r = arr.map(Number);
或
r = arr.map(function (value){
return parseInt(value);
});