js原型链的理解

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了js原型链的理解相关的知识,希望对你有一定的参考价值。

技术分享

function CreaterObj(){

  this.name = ‘Tom‘;

  this.age = 20;

}

var obj = new Creater();

理解:
1. 新对象由构造函数new 实例化出来;

2. 所有的对象都有__proto__属性,该属性对应该对象的原型,形成原型链
3. 所有的函数对象都有prototype属性,该属性的值会被赋值给该函数创建的对象的_proto_属性.
4. 所有的原型对象都有constructor属性,该属性对应创建所有指向该原型的实例的构造函数.
5. 函数对象和原型对象通过prototype和constructor属性进行相互关联.
new的实际操作:

1:创建一个新对象 obj = new Creater();

2:设置新对象的原型链 obj._proto_ = Creater.prototype;

3:改变构造函数Creater中的this指向,使this 指向obj;

4:判断F的返回值类型:
  如果是值类型,就丢弃它,还是返回obj。
  如果是引用类型,就返回这个引用类型的对象,替换掉暂存实例instance。

  注意:函数在没有返回值的情况下自动返回undefined,默认替换为obj










以上是关于js原型链的理解的主要内容,如果未能解决你的问题,请参考以下文章

JS中原型链的理解

js原型链和继承的理解

关于js中原型链的理解

js原型链的理解

js原型和原型链的简单理解

JS中原型链的理解