js中实现多态采用和继承类似的方法
作者:bea
多态的实现可以采用和继承类似的方法。首先定义一个抽象类,其中调用一些虚方法,虚方法在抽象类中没用定义,而是通过其具体的实现类来实现。 如下面的例子: Object.extend=function(destination,source){ for(property in source){ destination[property]=source[property]; } return destination; } //定义一个抽象基类base,无构造函数 function
多态的实现可以采用和继承类似的方法。首先定义一个抽象类,其中调用一些虚方法,虚方法在抽象类中没用定义,而是通过其具体的实现类来实现。
如下面的例子:
Object.extend=function(destination,source){
for(property in source){
destination[property]=source[property];
}
return destination;
}
//定义一个抽象基类base,无构造函数
function base(){};
base.prototype={
initialize:function(){
this.oninit();//调用了一个虚方法
}
}
function SubClassA(){
//构造函数
}
SubClassA.prototype=Object.extend({
propInSubClassA:"propInSubClassA",
oninit:function(){
alert(this.propInSubClassA);
}
},base.prototype);
function SubClassB(){
//构造函数
}
SubClassB.prototype=Object.extend({
propInSubClassB:"propInSubClassB",
oninit:function(){
alert(this.propInSubClassB);
}
},base.prototype);
var objA=new SubClassA();
objA.initialize();//输出"propInSubClassA"
var objB=new SubClassB();
objB.initialize();//输出"propInSubClassB"
首先定义了一个抽象基类base,在base类的initialize方法中调用了oninit方法,但是基类中并没用oninit方法的实现或者声明。SubClassA和SubClassB类继承自base类,并且分别采用了不同的方式对oninit方法进行实现。
猜你喜欢
您可能感兴趣的文章:
- Jquery通过JSON字符串创建JSON对象
- Jquery中扩展方法extend使用技巧
- jquery使用$(element).is()来判断获取的tagName
- jQuery响应鼠标事件并隐藏与显示input默认值
- js delete 用法(删除对象属性及变量)
- JQuery实现动态表格点击按钮表格增加一行
- js重写alert控件(适合学习js的新手朋友)
- 控制台报错object is not a function的解决方法
- Jquery仿IGoogle实现可拖动窗口示例代码
- JavaScript验证电子邮箱的函数
- jQuery实现列表自动滚动循环滚动展示新闻
- 用jquery修复在iframe下的页面锚点失效问题
- JavaScript实现的石头剪刀布游戏源码分享
- 一个很有趣3D球状标签云兼容IE8
- wap图片滚动特效无css3元素纯js脚本编写
- js在数组中删除重复的元素自保留一个(两种实现思路)
- js获取input长度并根据页面宽度设置其大小及居中对齐
- js使用正则实现ReplaceAll全部替换的方法
- IE浏览器IFrame对象内存不释放问题解决方法