JScript重载的另类实现
JScript重载的另类实现
发布时间:2016-12-30 来源:查字典编辑
摘要:JScript并不是面向对象的语言,只是基于对象。它没有重载这个概念,但通过一些技巧还是有办法从某种意义上实现重载。首先定义一个基类Test...

JScript并不是面向对象的语言,只是基于对象。它没有重载这个概念,但通过一些技巧还是有办法从某种意义上实现重载。

首先定义一个基类TestA,该类重写了Object继承下来的toString方法。

注:toString方法是用于序列化对象,比如说alert(a)相当于alert(a.toString());

引用:

functionTestA(Name)

{

this.Name=Name;

this.toString=function()

{

returnthis.Name;

}

}

接下来我们实现一个TestA类的派生类TestB:

引用:

functionTestB()

{

TestA.apply(this,arguments);

}

运行以下代码可以看出TestB已经继承下TestA的成员:

测试代码

[Ctrl+A 全选 注:如需引入外部Js需刷新才能执行]

现在我们来给TestB添加一个自己的toString方法,但问题是如果定义了TestB的toString,那么TestA继承下来的toString就被覆盖了,我的做法是:在重写之前先保存下TestA的toString为TestB的_TestA_toString,然后在TestB的toString中根据参数来判断要调用_TestA_toString还是TestB自己的toString代码

引用:

functionTestB()

{

TestA.apply(this,arguments);

this._TestA_toString=this.toString;//保存下TestA的toString

this.toString=function(isTestB)

{

if(isTestB)

{

return"TestB的Name是"+this.Name;

}

else

{

returnthis._TestA_toString();//这里调用TestA的toString,即_TestA_toString

}

}

}

以上的toString不单单是TestB自己的toString,还根据参数情况调用了原来的toString,实现了重载。

最终代码是:

引用:

functionTestA(Name)

{

this.Name=Name;

this.toString=function()

{

returnthis.Name;

}

}

functionTestB()

{

TestA.apply(this,arguments);

this._TestA_toString=this.toString;//保存下TestA的toString

this.toString=function(isTestB)

{

if(isTestB)

{

return"TestB的Name是"+this.Name;

}

else

{

returnthis._TestA_toString();//这里调用TestA的toString,即_TestA_toString

}

}

}

varB=newTestB("泣红亭");

alert(B);

alert(B.toString(true));

看看运行效果:

<html>

<head>

<metahttp-equiv="Content-Type"content="text/html;charset=gb2312">

<title>测试代码</title>

</head>

<body>

<script>

functionTestA(Name)

{

this.Name=Name;

this.toString=function()

{

returnthis.Name;

}

}

functionTestB()

{

TestA.apply(this,arguments);

this._TestA_toString=this.toString;//保存下TestA的toString

this.toString=function(isTestB)

{

if(isTestB)

{

return"TestB的Name是"+this.Name;

}

else

{

returnthis._TestA_toString();//这里调用TestA的toString,即_TestA_toString

}

}

}

varB=newTestB("泣红亭");

alert(B);

alert(B.toString(true));

</script>

</body>

</html>

提示:您可以先修改部分代码再运行

运行结果:

引用:

alert(B);//即alert(B.toString()),结果是"泣红亭"

alert(B.toString(true))//即isTestB为true,结果是"TestB的Name是泣红亭"

其实这样子不算是真正的重载,而是先保存原来的成员为一个副本,然后改写该成员,在新成员代码中根据参数再判断是否调用旧成员代码。

推荐文章
猜你喜欢
附近的人在看
推荐阅读
拓展阅读
相关阅读
网友关注
最新Javascript教程学习
热门Javascript教程学习
编程开发子分类