您的位置:首页 > 其它

深入了解parseInt

2012-09-22 23:11 106 查看
有这样一道题目

["1", "2", "3"].map(parseInt);  //[1, NaN, NaN]


为什么结果是这样?什么情况下返回NAN?

因为parseInt需要两个参数(val,radix),map传递了3个参数(elem,index,arr)。
如果想让parseInt(string,radix)返回NaN,有两种情况:

第1个参数不能转换成数字;

第2个参数不在2到36之间。

这里,我们猜测是第二种情况,重新定义parseInt(string,radix)函数试试。

//传递两个参数时
var parseInt = function(string, radix) {
return string + "-" + radix;
};
["1", "2", "3"].map(parseInt); //["1-0", "2-1", "3-2"]


//传递三个参数时
var parseInt = function(string, radix, obj) {
return string + "-" + radix + "-" + obj;
};
["1", "2", "3"].map(parseInt);//["1-0-1,2,3", "2-1-1,2,3", "3-2-1,2,3"]


//传递四个参数时
var parseInt = function(string, radix, obj, other) {
return string + "-" + radix + "-" + obj + "-" + other;
};
["1", "2", "3"].map(parseInt);
//["1-0-1,2,3-undefined", "2-1-1,2,3-undefined", "3-2-1,2,3-undefined"]


看见map方法确实向parseInt传递了三个参数,数组的值,索引,数组。
["1", "2", "3"]中的索引为0,1,2,如果1作为parseInt方法的第二个参数值,肯定有问题,因为不在2到36之间,所以返回NAN。2作为parseInt方法的第二个参数值,没有问题,但是字符串"3"里面没有合法的二进制数,所以也返回NAN。谜题最终揭晓,下面做一个扩展。

["1", "2", "3", "4", "5", "6", "7", "8", "9", "10", "11", "12", "13", "14", "15", "16"].map(parseInt);


//[1, NaN, NaN, NaN, NaN, NaN, NaN, NaN, NaN, 9, 11, 13, 15, 17, 19, 21]


parseInt("1", 0);    // 基数为0,默认10进制,返回1
parseInt("2", 1);    // 基数为1,不在2-36范围内,默认输出NaN
parseInt("3", 2);    // 基数为2,因为字符串3大于基数不合法,解析为NaN
parseInt("4", 3);    // 三进制
parseInt("5", 4);
parseInt("6", 5);
parseInt("7", 6);
parseInt("8", 7);
parseInt("9", 8);
parseInt("10", 9);   // 九进制 (1*9+0 = 9)
parseInt("11", 10);  // 十进制 (1*10+1 = 11)
parseInt("12", 11);
parseInt("13", 12);
parseInt("14", 13);
parseInt("15", 14);
parseInt("16", 15);
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: