码迷,mamicode.com
首页 > 其他好文 > 详细

原型和原型链

时间:2020-01-01 16:44:37      阅读:76      评论:0      收藏:0      [点我收藏+]

标签:bsp   str   UNC   color   ===   prototype   obj   rop   new   

每一个函数都有一个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 

 

原型和原型链

标签:bsp   str   UNC   color   ===   prototype   obj   rop   new   

原文地址:https://www.cnblogs.com/lyraLee/p/12128954.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!