关于JavaScript中原型继承中的一点思考


Posted in Javascript onJuly 25, 2012

我们先看一段传统的继承代码:

//定义超类 
function Father(){ 
this.name = "父亲"; 
} 
Father.prototype.theSuperValue = ["NO1","NO2"]; 
//定义子类 
function Child(){ 
} 
//实现继承 
Child.prototype = new Father(); 
//修改共享数组 
Child.prototype.theSuperValue.push("修改"); 
//创建子类实例 
var theChild = new Child(); 
console.log(theChild.theSuperValue); //["NO1","NO2","修改"] 
//创建父类实例 
var theFather = new Father(); 
console.log(theFather.theSuperValue); //["NO1","NO2","修改"]

通过上面的代码,我们注意“加红”的代码,子类Child的原型对象是父类Father的一个实例(new Father()),我们在这里是调用new Father()对象中的theSuperValue属性,因为new Father()对象中没有此属性(只有name属性),因此会沿着原型链向它的原型对象(Father.prototype)中去找,找到后发现是一个数组,而且是引用类型,此时我们往此数组中添加一个字符串“修改”。

之后,我们新建了Child的实例对象theChild,当theChild调用theSuperValue属性时,首先它自己里面没有此属性,就会去它的原型对象(new Father)中去找,可惜这里也没有,接着会到new Father()的原型中去找,OK,在Father.prototype中找到了这个数组,发现是["NO1","NO2","修改"]。

再接着,我们创建了Father的实例对象theFather,同上,我们在Father.prototype中找到了这个引用类型的数组["NO1","NO2","修改"]。(当然,数组都是引用类型的!)

通过上面的赘述,本来已经理解原型链概念的朋友觉得是废话连篇,其实我也是呵呵,接下来我们再看一个相似的例子:

//定义超类 
function Father() { 
this.name = "父亲"; 
} 
Father.prototype.theSuperValue = ["NO1", "NO2"]; 
//定义子类 
function Child() { 
} 
//实现继承 
Child.prototype = new Father(); 
//修改共享数组 
Child.prototype.theSuperValue = ["我是覆盖代码"] 
//创建子类实例 
var theChild = new Child(); 
console.log(theChild.theSuperValue); 
//创建父类实例 
var theFather = new Father(); 
console.log(theFather.theSuperValue);

我们看一下上面的代码,我用一种比较特别的紫色标注了此段代码与上段代码的小小区别,但结果却发生了“巨大”变化,见下面的截图:

关于JavaScript中原型继承中的一点思考

为什么我说是巨大变化,是因为我们从“重用公共属性”过渡到“覆盖公共属性,建立自己特色属性”上来!我这里是用数组演示的,其实第二种情况常常用在Function中,用子类的方法来覆盖父类的方法。

在第二段代码中,我们需要关注的是紫色代码前的“=”号,它是赋值操作符。如果我们对Child.prototype及new Father()对象调用这个赋值操作符时,我们就在这个对象上“新建”了一个属性,当在下面的theChild实例上调用theSuperValue时,返回的当然是新属性值["我是覆盖代码"]。

但当我们新创建一个父类实例theFather对象时,调用该对象上的theSuperValue属性,我们就会发现对象上并没有啊,这是为什么呢?因为我们刚才覆盖的是Father对象new Father();而不是Father类,所以,通过Fater()构造函数创建的新对象theFather并不包含新建的属性,当然,接下来的事情大家都明白,就是沿着原型链向上找,OK,在Father.prototype中找到了,就是我们一开始定义的那个数组。

通过上面两个例子,我们在JS中使用原型提供的继承功能时,尤其是利用子对象操作原型方法、对象时,切记“=”号赋值与引用调用这两种不同的操作,因为他们会带来完全不同的结果。

Javascript 相关文章推荐
JQuery 学习笔记 选择器之一
Jul 23 Javascript
Prototype Selector对象学习
Jul 23 Javascript
JavaScript实现移动端滑动选择日期功能
Jun 21 Javascript
第六篇Bootstrap表格样式介绍
Jun 21 Javascript
常用js,css文件统一加载方法(推荐) 并在加载之后调用回调函数
Sep 23 Javascript
详解js的事件处理函数和动态创建html标记方法
Dec 16 Javascript
最后说说Vue2 SSR 的 Cookies 问题
May 25 Javascript
详解webpack-dev-server使用方法
Sep 14 Javascript
微信小程序Flex布局用法深入浅出分析
Apr 25 Javascript
微信小程序wx.request拦截器使用详解
Jul 09 Javascript
微信小程序如何引用外部js,外部样式,公共页面模板
Jul 23 Javascript
(开源)微信小程序+mqtt,esp8266温湿度读取
Apr 02 Javascript
原生js 秒表实现代码
Jul 24 #Javascript
javascript设计模式 接口介绍
Jul 24 #Javascript
javascript设计模式 封装和信息隐藏(上)
Jul 24 #Javascript
js+xml生成级联下拉框代码
Jul 24 #Javascript
40个新鲜出炉的jQuery 插件和免费教程[上]
Jul 24 #Javascript
基于jquery的跟随屏幕滚动代码
Jul 24 #Javascript
基于JQuery的类似新浪微博展示信息效果的代码
Jul 23 #Javascript
You might like
php数组的概述及分类与声明代码演示
2013/02/26 PHP
解析php中heredoc的使用方法
2013/06/17 PHP
PHP中怎样保持SESSION不过期 原理及方案介绍
2013/08/08 PHP
php过滤XSS攻击的函数
2013/11/12 PHP
自己写的php中文截取函数mb_strlen和mb_substr
2015/02/09 PHP
PHP实现清除MySQL死连接的方法
2016/07/23 PHP
PHP函数引用返回的实例详解
2016/09/11 PHP
php原生导出excel文件的两种方法(推荐)
2016/11/19 PHP
PHP基于接口技术实现简单的多态应用完整实例
2017/04/26 PHP
php+ajax实现异步上传文件或图片功能
2017/07/18 PHP
实例介绍PHP中zip_open()函数用法
2019/02/15 PHP
js类中获取外部函数名的方法
2007/08/19 Javascript
textarea中的手动换行处理的jquery代码
2011/02/26 Javascript
JS网页图片按比例自适应缩放实现方法
2014/01/15 Javascript
javascript高级编程之函数表达式 递归和闭包函数
2015/11/29 Javascript
AngularJS单选框及多选框实现双向动态绑定
2016/01/13 Javascript
Bootstrap Modal对话框如何在关闭时触发事件
2016/12/02 Javascript
JS实现的简单拖拽购物车功能示例【附源码下载】
2018/01/03 Javascript
微信小程序中时间戳和日期的相互转换问题
2018/07/09 Javascript
微信小程序实现bindtap等事件传参
2019/04/08 Javascript
Python实现正整数分解质因数操作示例
2018/08/01 Python
Python并发之多进程的方法实例代码
2018/08/15 Python
Python实现多级目录压缩与解压文件的方法
2018/09/01 Python
解决python3捕获cx_oracle抛出的异常错误问题
2018/10/18 Python
pyinstaller打包opencv和numpy程序运行错误解决
2019/08/16 Python
基于Python实现2种反转链表方法代码实例
2020/07/06 Python
Rag & Bone官网:瑞格布恩高级成衣
2018/04/19 全球购物
eVitamins日本:在线购买折扣维生素、补品和草药
2019/04/04 全球购物
匡威西班牙官网:Converse西班牙
2019/10/01 全球购物
法学专业毕业生自荐信
2014/06/11 职场文书
2014年英语教研组工作总结
2014/12/06 职场文书
优秀班主任先进事迹材料
2014/12/16 职场文书
2015入党自荐书范文
2015/03/05 职场文书
付款证明模板
2015/06/19 职场文书
go类型转换及与C的类型转换方式
2021/05/05 Golang
css布局巧妙技巧之css三角示例的运用
2022/03/16 HTML / CSS