44个javascript问题-1(来自知乎)

看如下代码的输出
console.log(["1", "2", "3"].map(parseInt));
第一感觉输出[1,2,3],实际输出[1,NaN,NaN],下面先看看map函数系统给传入了哪些参数
var arr = ["1", "2", "3"].map(function(){console.log(arguments)});
以上代码在node环境下的输出为:
{ '0': '1', '1': 0, '2': [ '1', '2', '3' ] }
{ '0': '2', '1': 1, '2': [ '1', '2', '3' ] }
{ '0': '3', '1': 2, '2': [ '1', '2', '3' ] }
可以看出map所需传入的回调函数中,系统会自动传入3个参数:元素值,元素索引值,源数组,对于parseInt函数来说,有两个参数,第一个参数是需要转换的字符串,第二个参数是进制,以上代码当执行map函数时,当遍历到第二个元素'2'时,系统自动传给parseInt的两个参数是'2'和1,但是parseInt('2',1)显然返回NaN,因为1进制下parseInt无论第一个参数传什么都返回NaN,对于parseInt('3',2)而言,由于二进制下只有0和1,所以当第一个参数是3时函数就懵逼了,所以开始的代码最终会返回[1,NaN,NaN]

猜你喜欢

转载自blog.csdn.net/gunsmoke/article/details/86622733