关于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 相关文章推荐
IE FF OPERA都可用的弹出层实现代码
Sep 29 Javascript
Javascript公共脚本库系列(一): 弹出层脚本
Feb 24 Javascript
json2.js的初步学习与了解
Oct 06 Javascript
js DOM 元素ID就是全局变量
Sep 20 Javascript
JQuery 使用attr方法实现下拉列表选中
Oct 13 Javascript
JavaScript弹出新窗口后向父窗口输出内容的方法
Apr 06 Javascript
javascript表单验证大全
Aug 12 Javascript
jQuery插件passwordStrength密码强度指标详解
Jun 24 Javascript
常用的js方法合集
Mar 10 Javascript
浅谈Postman解决token传参的问题
Mar 31 Javascript
Node.js折腾记一:读指定文件夹,输出该文件夹的文件树详解
Apr 20 Javascript
浅入深出Vue之组件使用
Jul 11 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答题类应用接口实例
2015/02/09 PHP
PHP的伪随机数与真随机数详解
2015/05/27 PHP
PHP注释语法规范与命名规范详解篇
2018/01/21 PHP
thinkPHP+LayUI 流加载实现功能
2019/09/27 PHP
php下的原生ajax请求用法实例分析
2020/02/28 PHP
JQuery最佳实践之精妙的自定义事件
2010/08/11 Javascript
JavaScript类和继承 prototype属性
2010/09/03 Javascript
微博@符号的用户名提示效果。(想@到谁?)
2010/11/05 Javascript
浅析JQuery获取和设置Select选项的常用方法总结
2013/07/04 Javascript
javascript模拟C#格式化字符串
2015/08/26 Javascript
微信小程序 location API接口详解及实例代码
2016/10/12 Javascript
jquery.guide.js新版上线操作向导镂空提示jQuery插件(推荐)
2017/05/20 jQuery
浅谈关于.vue文件中style的scoped属性
2017/08/19 Javascript
bootstrap select2插件用ajax来获取和显示数据的实例
2018/08/09 Javascript
JS实现集合的交集、补集、差集、去重运算示例【ES5与ES6写法】
2019/02/18 Javascript
Vue调用后端java接口的实例代码
2019/10/28 Javascript
jQuery 淡入/淡出效果函数用法分析
2020/05/19 jQuery
vue实现单一筛选、删除筛选条件
2020/10/26 Javascript
对django 模型 unique together的示例讲解
2019/08/06 Python
Python如何基于selenium实现自动登录博客园
2019/12/16 Python
pytorch程序异常后删除占用的显存操作
2020/01/13 Python
PyCharm中如何直接使用Anaconda已安装的库
2020/05/28 Python
python打开音乐文件的实例方法
2020/07/21 Python
使用HTML和CSS实现的标签云效果(附demo)
2021/02/03 HTML / CSS
哥伦比亚加拿大官网:Columbia Sportswear Canada
2020/09/07 全球购物
外企C语言笔试题
2013/11/10 面试题
医药专业应届毕业生求职信范文
2014/01/01 职场文书
共产党员承诺书
2014/03/25 职场文书
五水共治捐款倡议书
2014/05/14 职场文书
离婚协议书怎么写的
2014/12/14 职场文书
公司行政助理岗位职责
2015/04/11 职场文书
公司表扬稿范文
2015/05/05 职场文书
致创业的您:这类人不适合餐饮创业
2019/08/19 职场文书
CSS 制作波浪效果的思路
2021/05/18 HTML / CSS
MySQL GRANT用户授权的实现
2021/06/18 MySQL
Java使用Unsafe类的示例详解
2021/09/25 Java/Android