问题描述与答案
求下面表达式的结果
[“1”, “2”, “3”].map(parseInt)
答案: [1, NaN, NaN]
答案解析
map
先说说map方法
- map() 方法接收一个函数做为参数,遍历数组,依次用回调函数处理数组元素,回调函数会被接收三个参数,currentValue,index,arr
- map() 方法返回一个新数组,数组中的元素为原始数组元素调用函数处理后的值
- map() 方法按照原始数组元素顺序依次处理元素。
- 注意: map() 不会对空数组进行检测
- 注意: map() 不会改变原始数组。
parseInt
说明
由于map的回调函数接收currentValue,index,arr三个参数,所以此题中,parseInt也被接收currentValue,index,arr这三个参数,
那么原题就相当于输出 [parseInt(“1”,0),parseInt(“2”,1),parseInt(“3”,2)]
当参数 radix 的值为 0,或没有设置该参数时,parseInt() 会根据 string 来判断数字的基数。所以parseInt(“1”,0)为1
1不在2~36之间,parseInt(“2”,1)为NaN
字符串"3"里面没有合法的二进制数,parseInt(“3”,2)为NaN
所以最后结果是[1,NaN,NaN]
parseFloat
既然都说到了parseInt,那么自然也得说说parseFloat
还得注意的是,parseFloat如果碰到的是如“23334”一样的整数字符串,那么返回的也是整数23334,不会自动加上小数点,如果碰到的是如“23334.5555”一样的整数字符串,那么返回的是23334.5555
parseFloat只接收一个参数,即字符串