导火索:
我们将arguments类数组转化为类数组时使用这行代码:
var arg = Array.prototype.slice.call(arguments)
那么为什么是Array.prototype.slice.call,不是Array.slice.call
都在一条原型链上,不应该可以从下至上自动寻找调用吗? //幼稚的想法
错了,并不在一条原型链上
理论是这样的,我调用Array的方法没有找到,再去Array.__proto__上去寻找,而不是Array.prototype
而且:
Array.__proto__ === Array.prototype
//false
那我想一下Array.__proto__是什么?是Object.prototype?
Array.__proto__===Object.prototype
//false,也不对
Array是构造函数,那么它是Function的实例,那应该是这样的:
Array.__proto__ === Function.prototype
//true
回到最初的问题
这样我们就能理解为什么Array.slice.call不可以用了,因为Array虽然是个构造函数,但也是一个函数对象,有_proto__,Array中找不到slice,去Array的_proto__中找当然没有。
slice在Array.prototype中。
两个重要的点
1.找不到属性时去__proto__上去寻找,而不是.prototype。
2.构造函数也是函数对象,别忘了他们是Function的实例。
3.只有构造函数才有prototype。