本文实例讲述了javascript原型链学习记录之继承实现方式。分享给大家供大家参考,具体如下:
在慕课网学习继承的笔记:
继承的几种方式:
① 使用构造函数实现继承
function Parent(){ this.name = 'parent'; } function Child(){ Parent.call(this); //在子类函数体里面执行父类的构造函数 this.type = 'child';//子类自己的属性 }
Parent.call(this)
,this即实例,使用this执行Parent方法,那么就用this.name = 'parent'
把属性
挂载在了this(实例)上面,以此实现了继承。
缺点:以上只是让Child得到了Parent上的属性,Parent的原型链上的属性并未被继承。
② 使用原型链实现继承
function Parent(){ this.name = 'parent'; } function Child(){ this.type = 'child'; } Child.prototype = new Parent();
解释:Child.prototype === Chlid实例的__proto__ === Child实例的原型
所以当我们引用new Child().name
时,Child上没有,然后寻找Child的原型child.__proto__
即Child.prototype
即new Parent()
,Parent的实例上就有name属性,所以Child实例就在原型链上找到了name属性,以此实现了继承。
缺点:可以看出,Child的所有实例,它们的原型都是同一个,即Parent的实例:
var a = new Child(); var b = new Child(); a.__proto === b.__proto__; //true
所以,当使用 a.name = 'a'重新给name赋值时,b.name也变成了'a',反之亦然。
用instanceof和constructor都无法确认实例到底是Child的还是Parent的。
③ 结合前两种取长补短
function Parent(){ this.name = 'parent'; } function Child(){ Parent.call(this); this.type = 'child'; } Child.prototype = new Parent();
缺点:在Child()里面用Parent.call(this);
执行了一次Parent(),然后又使用Child.prototype = new Parent()
执行了一次Parent()。
改进1:
function Parent(){ this.name = 'parent'; } function Child(){ Parent.call(this); this.type = 'child'; } Child.prototype = Parent.prototype;
缺点:用instanceof和constructor都无法确认实例到底是Child的还是Parent的。
原因: Child.prototype = Parent.prototype
直接从Parent.prototype
里面拿到constructor,即Parent。
改进2:
function Parent(){ this.name = 'parent'; } function Child(){ Parent.call(this); this.type = 'child'; } Child.prototype = Object.create(Parent.prototype); Child.prototype.constructor = Child;
画图说明吧:
var a = new Child();
所以这样写我们就构造出了原型链。
更多关于JavaScript相关内容还可查看本站专题:《javascript面向对象入门教程》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript数学运算用法总结》
希望本文所述对大家JavaScript程序设计有所帮助。
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
更新日志
- 魔兽世界wlk暗牧一键输出宏是什么 wlk暗牧一键输出宏介绍
- 群星.1996-红不让台语原唱2辑【福和唱片】【WAV+CUE】
- 郭书瑶.2009-爱的抱抱(EP)【种子音乐】【FLAC分轨】
- 郑瑞芬.1989-BE.MY.BABY【现代】【WAV+CUE】
- 花钱请人每周放30万只不咬人的蚊子 防治登革热传播
- 饭制《第一后裔》丧尸版弗蕾娜
- 贝克汉姆亲临!2024FC品类游戏嘉年华圆满落幕
- 「命轨爻错之翼」风之翼发放说明
- 《原神》前瞻特别节目回顾长图
- 米游币抽抽乐-原神专场现已开启!
- 黑鸭子2001《风情中国HQCD》[日本版][WAV+CUE]
- 陈杰洲1990-成人礼[滚石][WAV+CUE]
- MarkAanderud-HandsFree(2024)[24-44,1]FLAC
- 孙露《观心》1:1母盘直刻限量版[低速原抓WAV+CUE][361M]
- 钟志刚《汽车DJ玩主》[低速原抓WAV+CUE][1G]