关于apply,Array.apply(null, {length:5})怎么理解 财富值47

2016-10-21 21:57发布

如何理解Array.apply(null, {length:5})的{length:5}?

我测试过
Array.apply(null, {length:5}) //返回[undefined, undefined, undefined, undefined, undefined]

Array.apply(null, [{length:5}])和Array({length:5})返回的结果是一样的,为
[[object Object] {
length: 5
}]

第二、三还能理解!第一种怎么理解?

12条回答
BD_1 - 这个人很懒,什么都没留下
1楼 · 2016-10-21 22:54.采纳回答

所以,Array.apply(null, { length: 5}) 相当于
Array(undefined, undefined, undefined, undefined, undefined)

实际 这个 和 Array 没有任何关系,只是碰巧 你使用 Array 时遇到了。

首先需要有个 函数,定义个 iAmArray;

我觉得这个问题应该从 Function.call和 Function.apply 来入手。
这两个 函数的方法 功能都是一样的,都是为了改变 this 的指向。
唯一的区别就是参数不一样,apply的第二个参数必须传入数组。

这里不用管this,下面是正常调用它的三种方式:

和ES6的Array.from有点类似, Array.from

apply() 的第一个参数是对象,第二个参数是数组,作为参数列表。

apply方式调用时,估计是一个小bug,只要是 Object,还有length,它就当作数组处理了,实际和 Array 没有任何关系,任何函数都会这样。

不请自来,这是个好问题,必须回答一下

{length: 5}理解为Array like,即类数组对象(包含length属性)。

Array.apply(null, {length: 5}) length为特殊字段,意思是生成一个长度为5的数组,由于没赋值,所以都是undefined, 如果要赋值,可以这样

一周热门 更多>