js中map()方法和apply()方法的总结

在学习vue.js的render函数时遇到一段代码如下:

render: function (createElement) {
  return createElement('div',
    Array.apply(null, { length: 20 }).map(function () {
      return createElement('p', 'hi')
    })
  )
}
由于对其中Array.apply和map不是很理解,于是便在网上查找资料后,总结如下,方便以后自己回顾时进行复习。

map()

map()方法返回一个由原数组中每个元素调用一个指定的方法后返回的值组成的一个新数组。map()方法就是一种数组的映射,[].map(callback,[thisObject]) callback=function(value,index,array){}

通常map方法在调用callback函数时,会传递三个参数:当前正在遍历的元素,元素的索引,当前数组本身

var list= [{name:'one',name:'two',name:'three'}];
list.map(function(value,index){reutrn index})  //[0,1,2]
list.map(function (value){return value.name}).join(",")  //one,two,three
对于["1","2","3"].map(parseInt)的返回值为[1,NaN,NaN]的解释

由于map的callback函数传递三个参数,而parseInt本身只需要两个参数,第一个为元素本身,第二个为进制数,所以在进行转换时,会忽略callback的第三个参数,而parseInt则会用元素的索引作为自己的进制转换数。最终结果就是[1,NaN,NaN]

Array.apply()

Array.apply(null,array)要求第二个参数是一个数组,Array.apply(null,[1,2,3])返回[1,2,3]

当第二个参数为一个带有length属性的对象时,则会当做一个数组来使用

所以Array.apply(null,{length:3})返回的结果为[undefined,undefined,undefined]




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值