原型和原型链

每一个函数都有一个prototype属性。

每一个对象都有一个__proto__属性。

函数本身是特殊的对象,所以它既有prototype属性,也有__proto__属性。

1. 实例对象的__proto === 其构造函数的prototype

class Animal {
  constructor(name) {
    this.name = name;
  }
}
const cat = new Animal('cat');
cat.__proto__ === Animal.prototype ; //true

2. Funcition,Object构造含糊本质上是个普通函数,也是特殊的对象。

他们既有__proto__属性,也有prototype属性。

Function.__proto__ === Function.prototype; // true
Object.__proto__ === Function.prototype; //true

构造函数的__proto__属性,指向一个普通对象。普通对象的__proto__,指向Object.prototype。

Function.__proto__.__proto__ === Object.prototype; // true
Object.__proto__.__proto__ === Object.prototype; //true
Animal.prototype.__proto__ === Object.prototype; //true

3. 当查找对象的属性时,会先在对象自身查找,如果对象本身没有,会查找其__proto__链上的属性。

原型链的顶层是null。

Object.prototype.__proto__ === null

4. 查找对象自身的属性hasOwnProperty

const a = {self: 1};
a.hasOwnProperty('self'); // true

查找原型链上的属性in

const a = {self: 1};
a.__proto__.b = 2;

'b' in a; // true 
原文地址:https://www.cnblogs.com/lyraLee/p/12128954.html