如何理解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
}]
第二、三还能理解!第一种怎么理解?
付费偷看金额在0.1-10元之间
所以,
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.fromapply()
的第一个参数是对象,第二个参数是数组,作为参数列表。apply方式调用时,估计是一个小bug,只要是 Object,还有length,它就当作数组处理了,实际和 Array 没有任何关系,任何函数都会这样。
不请自来,这是个好问题,必须回答一下
{length: 5}
理解为Array like
,即类数组对象(包含length
属性)。Array.apply(null, {length: 5})
length
为特殊字段,意思是生成一个长度为5的数组,由于没赋值,所以都是undefined
, 如果要赋值,可以这样一周热门 更多>