最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • JavaScirpt基础之原型链

    正文概述 掘金(hello大白菜)   2020-12-04   676

    写在前面,JavaScirpt 是通过原型链来实现面向对象语言中的继承的,按照“你不知道的 JavaScirpt ”中的说法跟准确点,JavaScirpt没有继承只有委托,JavaScript 只是在两个对象之间创建一个关联。真正的继承是子类复制父类的操作。

    实践中理解

    一般开发中很少去关注原型链(开发框架除外),面试问的比较多点

    一个面试题开始

    Function.prototype.a = () => {
    	console.log(1);
    }
    Object.prototype.b = () => {
    	console.log(2);
    }
    function A() {}
    const a = new A();
    
    a.a(); //报错
    a.b();  // 2
    A.a();  // 1
    A.b(); // 2
    

    如果是已经理解了原型和原型链的一眼就可以看出来结果

    原型链关系图

    JavaScirpt基础之原型链

    看图说话

    按照原型链关系图分析上面的面试题

    • Function.prototype原型对象上添加了一个属性a函数
    • Object.prototype原型对象上添加了一个属性b函数
    • 自定义一个构造函数A,JavaScirpt中定义一个函数默认会生成一个prototype属性
    • new关键字调用构造函数A,创建一个新对象,构造函数A.prototype属性赋值给新对象的__prtot__属性
    • 调用a对象上的a方法,a对象自身没有,通过__prtot__属性找到它的原型对象A.prototype,原型对象也是一个对象,是对象就有原型。原型对象也没有继续向上找,找到原型对象的原型Object.prototype,找到Object.prototype也算是找到头了,如果没有返回undefined,这里用方法的形式调用undefined肯定报错啦
    • 调用a对象的b方法,按上面找寻的方式,对象最终都会找到Object.prototype,就会打印2
    • 调用A函数对象的a方法,JavaScirpt中所有函数式声明和函数表达式都是Function构造函数的实例,函数其实也是个对象,按照图上的关系这里的a方法会找到Function.prototype上定义的a,打印1
    • 调用A函数对象的b方法,按照图上的关系,会先找到Function.prototype上,Function.prototype其实也就个对象字面量,对象都是通过Object构造函数创建的,那可不最后就找到Object.prototype上了,打印2

    一个个的介绍

    prototype

    刚刚上章提到了函数定义后会自动帮我们生成一个prototype属性,那prototype指向哪里,指向一个字面量方式创建的对象,这个对象也是new关键字调用构造函数而创建实例的原型

    _prtot_

    __prtot__属性不是ES规范中定义的,大部分浏览器默认支持的,方便对象直接访问自己的原型

    console.log(a.__proto__ === A.prototype) //true
    

    constructor

    constructor是原型对象生成的一个属性,默认指向关联的构造函数,通常对象直接获取constructor,都是它原型上的constructor属性

    console.log(a.constructor) // A构造函数
    

    原型链

    什么是原型链,每个对象在创建的时候就会关联上一个原型对象,原型对象也是对象,继续关联它自己的原型对象。每一个对象都会从原型"继承"(委托更贴切)属性,这就是原型链

    原型链的头是Object.prototype,找到这就不会继续找下去了,Object.prototype的原型指向的是null,也就是啥也没有了。

    向toString,valueOf这些方法就是定义在Object.prototype上的,我们创建的普通对象调用这些方法就通过原型链找到的。

    在来捋捋原型链关系图

    • p对象是Pers构造函数的实例,p对象的原型指向Pers.prototype
    • Pers构造函数是Function构造函数(内置)的实例,Pers函数对象原型指向Function.prototype
    • Pers.prototype和Function.prototype原型也是个对象,JavaScirpt中的普通对象都是Object构造函数的实例,最终所有的对象的原型都指向Object.prototype
    • Object构造函数(内置)有是Function构造函数(内置)的实例

    是不是很有意思的一个关系网


    起源地下载网 » JavaScirpt基础之原型链

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元