ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

原型prototype

2021-09-14 01:03:14  阅读:158  来源: 互联网

标签:proto 对象 Object 原型 prototype 属性


原型prototype

  • 一个函数就是一个对象,一个对象不一定是一个函数,创建的每一个函数,解析器都会向函数中添加一个属性prototype

  • 这个属性对应着一个对象,这个对象就是所谓的原型对象

    • 函数作为普通函数调用时,它有prototype属性指向该函数的原型对象
    • 函数以构造函数的形式调用时,它所创建的对象都会有一个隐藏的属性,指向该函数的原型对象,我们可以通_proto_来访问该属性
      在这里插入图片描述
      在这里插入图片描述
  • 创建的对象中的属性和它的原型对象中的属性

    function a(){
    
    }
    a.prototype.name = "我是原型对象中的名字"
    var b = new a();
    
    //使用in检查对象中是否含有某个属性,这时如果对象中没有而原型对象中有,也会返回true
    console.log(”name" in b)  //true
    
    //可以使用对象中的hasOwnProperty()来检查对象自身中是否含有属性
    console.log(b.hasOwnProperty("name")); //false
    
    //hasOwnProperty()来自那里?
    console.log(b.hasOwnProperty("hasOwnProperty")) //false
    console.log(b._proto_._proto_.hasOwnProperty("hasOwnProperty"))  //true
    //当我们使用一个对象的属性或方法时,会在自身中寻找,自身中有,则直接使用,如果自身没有就到原型对象中寻找,如果原型对象中没有,就到原型对象的原型对象使用。。。直到找到Object对象的原型,Object对象()的原型就没有原型了,就是最终的,依然没有找到,则返回undefined。
    //Object对象(b._proto_)
    //Object对象的原型对象(b._proto_._proto_)
    console.log(Object.prototype === b._proto_._proto_) // true
    console.log(Object.prototype.__proto__ === null) // true (Object对象的原型对象是最终的,它再也没有原型对象)
    
  • 原型对象相当于一个公共的区域,所有同一类的实例可以访问到这个原型对象。可以将对象中共有的内容设置到原型对象中。以后创建构造函数时,可以将这些对象共有的属性和方法统一添加到构造函数的原型对象中,这样不用分别为每一个对象添加,也不会影响到全局作用域,可以使每个对象都具有这些属性和方法

原型链

  • 当我们访问一个对象的属性或者方法时,它会先在对象自身中寻找,找到则返回,如果没找到就到原型对象中找。这就像一条链一样。最终找到Object对象的原型,还是没有才返回undefined

标签:proto,对象,Object,原型,prototype,属性
来源: https://www.cnblogs.com/sonsmart/p/15265707.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有