javascript原型链学习记录之继承实现方式分析


Posted in Javascript onMay 01, 2019

本文实例讲述了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.prototypenew 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数学运算用法总结》

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
Javascript写入txt和读取txt文件示例
Feb 12 Javascript
Javascript定义类(class)的三种方法详解
Mar 13 Javascript
浅谈jQuery中replace()方法
May 13 Javascript
jQuery实现checkbox全选的方法
Jun 10 Javascript
jquery使整个div区域可以点击的方法
Jun 24 Javascript
总结JavaScript中布尔操作符||与&&的使用技巧
Nov 17 Javascript
jquery中键盘事件小结
Feb 24 Javascript
简单掌握JavaScript中const声明常量与变量的用法
May 21 Javascript
jQuery实现的简单排序功能示例【冒泡排序】
Jan 13 Javascript
VUE开发一个图片轮播的组件示例代码
Mar 06 Javascript
underscore之Collections_动力节点Java学院整理
Jul 10 Javascript
vue实现自定义日期组件功能的实例代码
Nov 06 Javascript
微信小程序实现卡片左右滑动效果的示例代码
May 01 #Javascript
微信小程序常见页面跳转操作简单示例
May 01 #Javascript
浅谈对于react-thunk中间件的简单理解
May 01 #Javascript
vue增加强缓存和版本号的实现方法
May 01 #Javascript
vue组件化中slot的基本使用方法
May 01 #Javascript
Vue基本使用之对象提供的属性功能
Apr 30 #Javascript
原生JS实现随机点名项目的实例代码
Apr 30 #Javascript
You might like
动漫定律:眯眯眼都是怪物!这些角色狠话不多~
2020/03/03 日漫
自己动手做一个SQL解释器
2006/10/09 PHP
模拟OICQ的实现思路和核心程序(一)
2006/10/09 PHP
Admin generator, filters and I18n
2011/10/06 PHP
PHP中register_globals参数为OFF和ON的区别(register_globals 使用详解)
2012/02/05 PHP
PHP实现数字补零功能的2个函数介绍
2014/05/12 PHP
php发送与接收流文件的方法
2015/02/11 PHP
JavaScript与HTML结合的基本使用方法整理
2015/10/12 PHP
传智播客学习之JavaScript基础篇
2009/11/13 Javascript
怎么清空javascript数组
2013/05/11 Javascript
如何调试异步加载页面里包含的js文件
2014/10/30 Javascript
angularJS中$apply()方法详解
2015/01/07 Javascript
详解JavaScript的while循环的使用
2015/06/03 Javascript
Angularjs CURD 详解及实例代码
2016/09/14 Javascript
js实现表格筛选功能
2017/01/18 Javascript
Angular 2父子组件数据传递之局部变量获取子组件其他成员
2017/07/04 Javascript
vue .js绑定checkbox并获取、改变选中状态的实例
2018/08/24 Javascript
layui表格分页 记录勾选的实例
2019/09/02 Javascript
layer弹窗在键盘按回车将反复刷新的实现方法
2019/09/25 Javascript
解决Vue中的生命周期beforeDestory不触发的问题
2020/07/21 Javascript
OpenLayers3实现对地图的基本操作
2020/09/28 Javascript
[01:16:50]DOTA2-DPC中国联赛 正赛 Phoenix vs CDEC BO3 第一场 3月7日
2021/03/11 DOTA
基于python的字节编译详解
2017/09/20 Python
Django添加feeds功能的示例
2018/08/07 Python
Anaconda+spyder+pycharm的pytorch配置详解(GPU)
2020/10/18 Python
python-jwt用户认证食用教学的实现方法
2021/01/19 Python
CSS3的column-fill属性对齐列内容高度的用法详解
2016/07/01 HTML / CSS
HTML5给汉字加拼音收起展开组件的实现代码
2020/04/08 HTML / CSS
KIKO美国官网:意大利的平价彩妆品牌
2017/05/16 全球购物
如何拷贝一整个Java对象,包括它的状态
2013/12/27 面试题
写给女生的道歉信
2014/01/08 职场文书
小班秋游活动方案
2014/02/22 职场文书
教师批评与自我批评剖析材料
2014/10/16 职场文书
2014年保密工作总结
2014/11/22 职场文书
上市公司董事长岗位职责
2015/04/16 职场文书
教你利用Selenium+python自动化来解决pip使用异常
2021/05/20 Python