作家
登录

JScript重载的另类实现

作者: 来源:www.28hudong.com 2013-03-30 03:48:58 阅读 我要评论

JScript并不是面向对象的语言,只是基于对象。它没有重载这个概念,但通过一些技巧还是有办法从某种意义上实现重载。 首先定义一个基类TestA,该类重写了Object继承下来的toString方法。 注:toString方法是用于序列化对象,比如说alert(a)相当于alert(a.toString()); 引用: function TestA(Name) { this.Name = Name; this.toString = function () { return this.Name; } } 接下来我们实现一个TestA类的派生类TestB: 引用: function TestB() { 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代码 引用: function TestB() { TestA.apply(this, arguments); this._TestA_toString = this.toString; // 保存下TestA的toString this.toString = function(isTestB) { if(isTestB) { return "TestB的Name是" + this.Name; } else { return this._TestA_toString(); // 这里调用TestA的toString,即_TestA_toString } } } 以上的toString不单单是TestB自己的toString,还根据参数情况调用了原来的toString,实现了重载。 最终代码是: 引用: function TestA(Name) { this.Name = Name; this.toString = function() { return this.Name; } } function TestB() { TestA.apply(this, arguments); this._TestA_toString = this.toString; // 保存下TestA的toString this.toString = function(isTestB) { if(isTestB) { return "TestB的Name是" + this.Name; } else { return this._TestA_toString(); // 这里调用TestA的toString,即_TestA_toString } } } var B = new TestB("泣红亭"); alert(B); alert(B.toString(true)); 看看运行效果: <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=gb2312"> <title>测试代码</title> </head> <body> <script> function TestA(Name) { this.Name = Name; this.toString = function() { return this.Name; } } function TestB() { TestA.apply(this, arguments); this._TestA_toString = this.toString; // 保存下TestA的toString this.toString = function(isTestB) { if(isTestB) { return "TestB的Name是" + this.Name; } else { return this._TestA_toString(); // 这里调用TestA的toString,即_TestA_toString } } } var B = new TestB("泣红亭"); alert(B); alert(B.toString(true)); </script> </body> </html> 提示:您可以先修改部分代码再运行 运行结果: 引用: alert(B); // 即alert(B.toString()), 结果是"泣红亭" alert(B.toString(true)) // 即isTestB为true,结果是"TestB的Name是泣红亭" 其实这样子不算是真正的重载,而是先保存原来的成员为一个副本,然后改写该成员,在新成员代码中根据参数再判断是否调用旧成员代码。

  推荐阅读

  Prototype使用指南之hash.js

Hash对象(关联数组)是Prototype新建的一个对象,要创建一个Hash对象可以调用$H(object)方法,因为javascript本身的特点(对象本身就是关联数组) ,所以实现Hash也很简单,Prototype中的Hash只是javascript的关联数组>>>详细阅读


本文标题:JScript重载的另类实现

地址:http://www.17bianji.com/kaifa2/JS/31098.html

关键词: 探索发现

乐购科技部分新闻及文章转载自互联网,供读者交流和学习,若有涉及作者版权等问题请及时与我们联系,以便更正、删除或按规定办理。感谢所有提供资讯的网站,欢迎各类媒体与乐购科技进行文章共享合作。

网友点评
自媒体专栏

评论

热度

精彩导读
栏目ID=71的表不存在(操作类型=0)