js数组的map方法以及parseInt方法
2014-02-10 14:10
411 查看
无意看到一个方法:
["1", "2", "3"].map(parseInt);
返回值为:[1, NaN, NaN]。
好奇查了下map方法的用法如下:
也就是数组都调用了parseInt方法,但是为什么返回的值却不同呢。因为
参考链接:
https://developer.mozilla.org/zh-CN/docs/JavaScript/Reference/Global_Objects/Array/map
http://www.w3school.com.cn/js/jsref_parseInt.asp
["1", "2", "3"].map(parseInt);
返回值为:[1, NaN, NaN]。
好奇查了下map方法的用法如下:
map方法会给原数组中的每个元素(必须有值)都调用一次
callback函数。
callback每次执行后的返回值组合起来形成一个新数组。
callback函数只会在有值的索引上被调用,那些从来没被赋过值或者使用delete删除的索引则不会被调用。
也就是数组都调用了parseInt方法,但是为什么返回的值却不同呢。因为
callback函数会被自动传入三个参数:数组元素,元素索引,原数组本身。而parseInt方法是可以接收两个参数的,第一个为被转化的值,第二个为被转化值的进制。map自动传入的第二个参数被当做进制了,也就是数组的index被当做进制数了。当进制数为0时,默认为10进制,故结论数组第一个值为1,。当parseInt的进制参数小于2或者大于36,就返回NaN,因此第二个值为NaN。第三个值为NaN的原因是相当于执行了parseInt("3","2"),而2进制下数字3是不存在的,也返回了NaN。
参考链接:
https://developer.mozilla.org/zh-CN/docs/JavaScript/Reference/Global_Objects/Array/map
http://www.w3school.com.cn/js/jsref_parseInt.asp
相关文章推荐
- js---原生JS数组arr遍历方法forEach()和map()遍历的区别以及兼容写法
- JS数组方法总结shift()、unshift()、pop()、push()、concat()、splice()、filter()、map()、some()、every()、forEach()等方法
- js---js中数组遍历方法forEach与map()有什么区别?
- js巧用apply方法实现数组最值以及合并
- JS数组中every(),filter(),forEach(),map(),some()方法学习笔记!
- js数组常用的方法:forEach、map、filter、every的对比
- js中数组的sort()方法用法,参数以及排序原理
- 笔记-JS数组遍历方法之forEach()和map()
- Js中自定义(创建)Map以及对应方法
- JS数组的属性以及方法
- 【js jQuery】map集合 循环迭代取值---以及 map、json对象、list、array循环迭代的方法和区别
- json对象与数组以及转换成js对象的方法
- JS基础学习第三天:变量是什么?什么是数组以及数组的方法?
- json对象与数组以及转换成js对象的简单实现方法
- js数组对象以及数组常用属性和方法
- Js数组的map,filter,reduce,every,some方法
- js 数组 map方法
- json对象与数组以及转换成js对象的简单实现方法
- JS数组的map方法
- JavaScript中的数组遍历forEach()与map()方法以及兼容写法介绍