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

2016-10-21 21:57发布

4194 12 2

如何理解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)

40人赞 添加讨论(1) 举报

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

79人赞 添加讨论(0)举报

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

66人赞 添加讨论(0)举报

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

61人赞 添加讨论(0)举报

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

60人赞 添加讨论(0)举报

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

58人赞 添加讨论(0)举报

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

51人赞 添加讨论(0)举报

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

50人赞 添加讨论(0)举报

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

41人赞 添加讨论(0)举报

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

30人赞 添加讨论(0)举报

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

29人赞 添加讨论(0)举报

一周热门 更多>