javascript - Array.apply(null, {length: 10})和Array(10)有什么区别?

查看:142
本文介绍了javascript - Array.apply(null, {length: 10})和Array(10)有什么区别?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

问 题

看了下, 对生成的数组测试

var arr1 = Array.apply(null, {length: 10});
var arr2 = Array(10);
0 in arr1  //true
0 in arr2  //false
arr1.map(function(item, index){console.log(index)}) //0, 1, 2, 3...
arr2.map(function(item, index){console.log(index)}) //undefined...

似乎第一种方法生成的数组确实生成了10个undefined组成的数组, 而第二种方法就是纯粹的空数组, 只有一个length属性?

解决方案

首先Array(1,2,3,4),你知道的吧,生成一个数组[1,2,3,4]
然后是apply的问题,要求第二个参数是一个数组
那么Array.apply(null,[1,2,3,4])生成的和上述的一样的[1,2,3,4]数组
但apply有个奇怪的地方,当第二个参数是一个带有length属性的对象时,会当成一个数组使用
所以Array.apply(null,{length:4})生成[undefined,undefined,undefined,undefined]
相当于Array.apply(null,[undefined,undefined,undefined,undefined])

这篇关于javascript - Array.apply(null, {length: 10})和Array(10)有什么区别?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆