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

夯实基础之--new关键字、instanceOf原理

时间:2019-04-19 11:49:53      阅读:163      评论:0      收藏:0      [点我收藏+]

标签:检测   原型   OLE   对象   prot   javascrip   函数   turn   显示   

1.instanceOf原理

 检测右边构造函数的prototype是否在左边对象的原型链上,在返回true,不在返回false

例:function  Persion(name,age){

    this.name = name;

               this.age  = age;

  } ; 

       let  p  = new  Persion()

       console.log( p   instanceOf  Persion )      //true

      对象p的原型链为:p.__proto__  ==   Persion.prototype   Persion.prototype .__proto__  ==  Object.prototype   Object.prototype.__proto__ == null

 

2.new关键字原理

 当执行代码new  Persion()时,会进行以下操作:

  • 创建一个空对象obj
  • 将obj的__proto__指向Persion.prototype
  • 显示的绑定this,Persion.call(obj,‘ ‘jake‘, 30)
  • 返回obj(前提是构造函数的返回值不是对象或者函数)

  伪代码实现如下:

  

let  obj  = {};

obj.__proto__  =  Persion.prototype;

Persion.call(obj, ‘jake‘, 30);

return  obj;
  

  

夯实基础之--new关键字、instanceOf原理

标签:检测   原型   OLE   对象   prot   javascrip   函数   turn   显示   

原文地址:https://www.cnblogs.com/zifayin/p/10734862.html

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