实现JavaScript中继承的三种方式


Posted in Javascript onOctober 16, 2009

一、原型链继承

在原型链继承方面,JavaScript与java、c#等语言类似,仅允许单父类继承。prototype继承的基本方式如下:

function Parent(){} 
function Child(){} 
Child.prototype = new Parent();

通过对象Child的prototype属性指向父对象Parent的实例,使Child对象实例能通过原型链访问到父对象构造所定义的属性、方法等。

构造通过原型链链接了父级对象,是否就意味着完成了对象的继承了呢?答案是否定的。如:

function Parent(){} 
function Child(){} 
Child.prototype = new Parent(); 
var child = new Child(); 
alert(child.constructor);//function Parent(){} 
alert(child instanceof Child);//true

尽管child依然可以作为Child的实例使用,但此时已经丢失了实例child原有的对象构造信息。弥补该缺陷的方法如下:

function Parent(){} 
function Child(){} 
Child.prototype = new Parent(); 
Child.prototype.constructor = Child; 
var child = new Child(); 
alert(child.constructor);//function Parent(){} 
alert(child instanceof Child);//true

如上代码片段“Child.prototype.constructor = Child”所示,通过显示地指定对象构造Child的原型,强制所有的Child对象实例的构造都为Child。
二、使用apply、call方法

由于JavaScript内置的Function对象的apply、call方法改变对象构造中“this”的上下文环境,使特定的对象实例具有对象构造中所定义的属性、方法。

使用apply、call继承,在实际开发中操作HTML页面上的DOM对象时尤为常用。如:

<div id="extend">apply,call继承</div> 

<script language="javascript"> 

function ext() 

{ 


 this.onclick=function(){alert(this.innerHTML)} 

} 

ext.apply(document.getElementById("extend")); 

ext.call(document.getElementById("extend")); 

</script>

通过apply或call定义的ext方法,使ext方法内部的this上下文表示为DOM对象“<div id="extend">apply,call继承</div>”。

值得注意的是,当使用apply、call时,会直接执行对象构造所定义的代码段,如:

<script language="javascript"> 

function testExec() 

{ 


 alert("执行!"); 

} 

testExec.call(null);//弹出execute对话框 

testExec.apply(null);//弹出execute对话框 

</script>

三、对象实例间的继承

JavaScript对象的多态性,允许实例动态地添加属性、方法。该特性造就了JavaScript中的另一种继承手法——对象实例间的继承。如:

var Person = {name:"nathena",age:"26"}; 

var nathena = {sex:"male"}; 

(function inlineExtends(so,po) 

{ 


for (var i in po) 


{ 



if (so[i])//如果so也具有这个成员 




continue; 



so[i] = po[i]; 


} 

})(nathena,Person); 

alert(nathena.name);//返回nathana

如以上代码所示,在对象的实例间继承中,父对象Persong定义了“人”所具有的共同属性name、age,子对象nathena定义了自己的私有属性“sex”。函数inlineExtends的功能是,为子对象nathena复制父对象Person中定义的“人”所具有的共同属性。

其中特别需要注意的语句是“if (so[i])”,此句确保了子对象原有的成员不被父对象中同名的成员所覆盖,而违背面向对象中父子对象之间继承的原则——子对象可以覆盖、重载父对象的属性或方法,父对象仅能对子对象隐藏自己的属性或方法。

Javascript 相关文章推荐
javascript 读取XML数据,在页面中展现、编辑、保存的实现
Oct 27 Javascript
Node.js入门教程:在windows和Linux上安装配置Node.js图文教程
Aug 14 Javascript
javascript中2个感叹号的用法实例详解
Sep 04 Javascript
jQuery实现按键盘方向键翻页特效
Mar 18 Javascript
省市区三级联动下拉框菜单javascript版
Aug 11 Javascript
jQuery 限制输入字符串长度
Jun 20 Javascript
浅谈jQuery中的checkbox问题
Aug 10 Javascript
基于Node.js + WebSocket打造即时聊天程序嗨聊
Nov 29 Javascript
js实现一个可以兼容PC端和移动端的div拖动效果实例
Dec 09 Javascript
使用JS和canvas实现gif动图的停止和播放代码
Sep 01 Javascript
详解在vue-cli中使用graphql即vue-apollo的用法
Sep 08 Javascript
详解vue项目中使用token的身份验证的简单实践
Mar 08 Javascript
显示js对象所有属性和方法的函数
Oct 16 #Javascript
半角全角相互转换的js函数
Oct 16 #Javascript
JavaScript 三种创建对象的方法
Oct 16 #Javascript
JQuery困惑—包装集 DOM节点
Oct 16 #Javascript
JavaScript 对象成员的可见性说明
Oct 16 #Javascript
Javascript 圆角div的实现代码
Oct 15 #Javascript
IE Firefox 使用自定义标签的区别
Oct 15 #Javascript
You might like
PHP 七大优势分析
2009/06/23 PHP
PHP实现的sqlite数据库连接类
2014/12/12 PHP
PHP多态代码实例
2015/06/26 PHP
如何写php守护进程(Daemon)
2015/12/30 PHP
PHP生成制作验证码的简单实例
2016/06/12 PHP
php获取是星期几的的一些常用姿势
2019/12/15 PHP
js 学习笔记(三)
2009/12/29 Javascript
ECMAScript 6即将带给我们新的数组操作方法前瞻
2015/01/06 Javascript
JavaScript列表框listbox全选和反选的实现方法
2015/03/18 Javascript
laypage分页控件使用实例详解
2016/05/19 Javascript
jQuery.Uploadify插件实现带进度条的批量上传功能
2016/06/08 Javascript
Javascript 跨域知识详细介绍
2016/10/30 Javascript
jQuery拖拽通过八个点改变div大小
2020/11/29 Javascript
完美实现js焦点轮播效果(二)(图片可滚动)
2017/03/07 Javascript
Nodejs实现多房间简易聊天室功能
2017/06/20 NodeJs
使用vue实现简单键盘的示例(支持移动端和pc端)
2017/12/25 Javascript
AngularJS使用ui-route实现多层嵌套路由的示例
2018/01/10 Javascript
nodejs初始化init的示例代码
2018/10/10 NodeJs
js实现磁性吸附的示例
2020/10/26 Javascript
Python检测一个对象是否为字符串类的方法
2015/05/21 Python
Python利用带权重随机数解决抽奖和游戏爆装备问题
2016/06/16 Python
一个基于flask的web应用诞生 使用模板引擎和表单插件(2)
2017/04/11 Python
Python实现对象转换为xml的方法示例
2017/06/08 Python
用Python一键搭建Http服务器的方法
2018/06/01 Python
django表单的Widgets使用详解
2019/07/22 Python
django框架模型层功能、组成与用法分析
2019/07/30 Python
Python实现CNN的多通道输入实例
2020/01/17 Python
Pycharm最常用的快捷键及使用技巧
2020/03/05 Python
Python loguru日志库之高效输出控制台日志和日志记录
2020/03/07 Python
如何用tempfile库创建python进程中的临时文件
2021/01/28 Python
美国最佳选择产品网站:Best Choice Products
2019/05/27 全球购物
英国标志性生活方式品牌:Skinnydip London
2019/12/15 全球购物
律师授权委托书范本
2014/10/07 职场文书
财务总监岗位职责
2015/02/03 职场文书
解决redis批量删除key值的问题
2022/03/23 Redis
Ruby处理YAML和json数据
2022/04/18 Ruby