原型、原型链、继承
-
每个对象都会在其内部初始化一个属性,就是prototype(原型),当我们访问一个对象的属性时
-
如果这个对象内部不存在这个属性,那么他就会去prototype里找这个属性,这个prototype又会有自己的prototype,于是就这样一直找下去,也就是我们平时所说的原型链的概念
-
关系:instance.constructor.prototype = instance.proto
特点:
JavaScript对象是通过引用来传递的,我们创建的每个新对象实体中并没有一份属于自己的原型副本。当我们修改原型时,与之相关的对象也会继承这一改变
当我们需要一个属性的时,Javascript引擎会先看当前对象中是否有这个属性, 如果没有的
就会查找他的Prototype对象是否有这个属性,如此递推下去,一直检索到 Object 内建对象
- 每个函数都有 prototype 属性,除了 Function.prototype.bind(),该属性指向原型。
- 每个对象都有 __proto__属性,指向了创建该对象的构造函数的原型。其实这个属性指向了 [[prototype]],但是 [[prototype]] 是内部属性,我们并不能访问到,所以使用 proto 来访问。
- 对象可以通过__proto__ 来寻找不属于该对象的属性,proto 将对象连接起来组成了原型链