首页 > 编程语言 > 详细

JavaScript中的显式原型链 prototype 和隐式原型 __proto__

时间:2021-04-27 20:17:02      阅读:25      评论:0      收藏:0      [点我收藏+]

直接上经典示图

技术分享图片

 

 

 原型prototype

我们平时在代码里所创建的每一个函数,解析器都会向函数中添加一个属性prototype,这个属性对应着一个对象,这个对象就是我们所谓的原型对象

如果函数作为普通函数调用prototype没有任何作用,当函数以构造函数的形式调用时,它创建的对象中都会有一个隐式的属性__proto__指向该构造函数的原型对象

原型对象就相当于一个公共的区域,所有同一个类的实例都可以访问到这个原型对象,我们可以将对象中共有的内容,统一设置到原型对象中

当我们访问对象的一个属性或方法时,它会先在对象自身中寻找,如果有则直接使用,如果没有则会去原型对象中寻找,如果找到则直接使用

 

原型对象

它也是对象,所有它也有原型,当我们使用一个对象的属性或方法时,会先在自身找,如果有直接使用,没有就去原型对象的原型中去找,直到找到Object对象的原型

Object对象的原型没有原型,如果在Object原型中依然没找到,则返回undefined

  function Fn() {}
  var fn = new Fn();
  
  console.log(Fn.prototype === fn.__proto__)  // true
  console.log(fn.__proto__.__proto__) // <object>
  console.log(fn.__proto__.__proto__.__proto__) // null

案例2

function Fn() {
    this.test1 = function() {
      console.log(11);
    }
  }
  Fn.prototype.test2 = function() {
    console.log(222);
  }
  var fn = new Fn();
  
  Fn.prototype.test3 = function() {
    console.log(333);
  }
  
  fn.test3(); // 333

  

JavaScript中的显式原型链 prototype 和隐式原型 __proto__

原文:https://www.cnblogs.com/bobo1/p/14709381.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!