.javascript如何使用继承
2017-04-23 20:32
239 查看
前言:大多OO语言都支持两种继承方式: 接口继承和实现继承 ,而ECMAScript中无法实现接口继承,ECMAScript只支持实现继承,而且其实现继承主要是依靠 原型链 来实现。
1.原型链
基本思想:利用原型让一个引用类型继承另外一个引用类型的属性和方法。
构造函数,原型,实例之间的关系:每个构造函数都有一个原型对象,原型对象包含一个指向构造函数的指针,而实例都包含一个指向原型对象的内部指针。
原型链实现继承例子:
?
2.借用构造函数
基本思想:在子类型构造函数的内部调用超类构造函数,通过使用call()和apply()方法可以在新创建的对象上执行构造函数。
例子:
?
3.组合继承
基本思想:将原型链和借用构造函数的技术组合在一块,从而发挥两者之长的一种继承模式。
例子:
?
4.原型式继承
基本想法:借助原型可以基于已有的对象创建新对象,同时还不必须因此创建自定义的类型。
原型式继承的思想可用以下函数来说明:
?
例子:
?
ECMAScript5通过新增Object.create()方法规范化了原型式继承,这个方法接收两个参数:一个用作新对象原型的对象和一个作为新对象定义额外属性的对象。
?
5.寄生式继承
基本思想:创建一个仅用于封装继承过程的函数,该函数在内部以某种方式来增强对象,最后再像真正是它做了所有工作一样返回对象。
例子:
?
6.寄生组合式继承
基本思想:通过借用函数来继承属性,通过原型链的混成形式来继承方法
其基本模型如下所示:
?
例子:
?
1.原型链
基本思想:利用原型让一个引用类型继承另外一个引用类型的属性和方法。
构造函数,原型,实例之间的关系:每个构造函数都有一个原型对象,原型对象包含一个指向构造函数的指针,而实例都包含一个指向原型对象的内部指针。
原型链实现继承例子:
?
基本思想:在子类型构造函数的内部调用超类构造函数,通过使用call()和apply()方法可以在新创建的对象上执行构造函数。
例子:
?
基本思想:将原型链和借用构造函数的技术组合在一块,从而发挥两者之长的一种继承模式。
例子:
?
基本想法:借助原型可以基于已有的对象创建新对象,同时还不必须因此创建自定义的类型。
原型式继承的思想可用以下函数来说明:
?
?
?
基本思想:创建一个仅用于封装继承过程的函数,该函数在内部以某种方式来增强对象,最后再像真正是它做了所有工作一样返回对象。
例子:
?
基本思想:通过借用函数来继承属性,通过原型链的混成形式来继承方法
其基本模型如下所示:
?
?
相关文章推荐
- 如何使用JavaScript进行可靠的继承调用
- 如何在ASP.NET中使用JavaScript脚本
- 在JavaScript面向对象编程中使用继承(1)
- 如何从客户端 JavaScript 调用 .NET Web 服务使用 InternetExplorer 和 MSXML
- 如何在WebForm中使用javascript防止连打(双击)
- 用javascript操作xml-->Web设计中如何使用XML数据源对象(转载)
- 绝对酷,如何解决asp.net中javascript脚本的问题(使用服务器控件执行客户端脚本)
- 在JavaScript面向对象编程中使用继承(1)
- 在JavaScript面向对象编程中使用继承(3)
- 如何在WebForm中使用javascript防止连打(双击)
- 在JavaScript面向对象编程中使用继承(2)
- 如何在ASP.NET中使用JavaScript脚本
- 在JavaScript面向对象编程中使用继承(1)
- 在JavaScript面向对象编程中使用继承(2)
- asp.net中窗口相关操作(如何使用javascript)
- 如何使用JavaScript来写ASP程序
- 在JavaScript面向对象编程中使用继承(5)
- 在JavaScript面向对象编程中使用继承(2)
- 如何使用Javascript XSLT 处理XML文件(2)
- 如何在ASP.NET中使用JavaScript脚本