JScript重载的另类实现

2016-02-19 10:59 6 1 收藏

给自己一点时间接受自己,爱自己,趁着下午茶的时间来学习图老师推荐的JScript重载的另类实现,过去的都会过去,迎接崭新的开始,释放更美好的自己。

【 tulaoshi.com - Web开发 】

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是泣红亭" 

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

来源:http://www.tulaoshi.com/n/20160219/1596295.html

延伸阅读
标签: Web开发
javascript(以下简称JS)不是一门真的的面像对像语言,在JS里并没有正式的类,即使没有真正的类,我们还是叫它类!在这里,我学习一下怎么在JS使用重载! 在JS中有一个特殊对像arguments,我们在开发中不需要显示指出它。如下:  function hello() {             aler...
标签: ASP
  griefforyou [原作] 亲爱的 GUI 博士: 我有一个关于 XML 的问题。我通过 XMLHTTP 发布一个 ASP 页面,将数据作为 HTML 发送回来,并在 div、表格单元格或任何元素上执行 object.innerHTML。 我遇到的问题是,有一次,我在 ASP 服务器页上创建一个表单,并将该表单以 HTML 发送回去,这样做一切正常。但我还希望对该页面进行客户端...
最长重载铁路铺轨 时代在进步,科技在发展,中国的铁路运输也越来越厉害,最长的重载铁路于蒙古举行了铺轨启动仪式,代表着这个项目建设进入了一个新的阶段。下面,是关于本项事件的具体详细内容,我们一起来关注一下。 蒙华铁路是我国在建最长重载铁路,北起内蒙古鄂尔多斯市乌审旗浩勒报吉南站,终至京九铁路江西吉安站,纵贯内蒙古、陕西...
标签: Web开发
IE中jscript/javascript的条件编译作者:JavaScript Kit 译者:子乌(Sheneyan) 翻译日期:2006-02-12 英文原文:Conditional Compilation of JScript/ JavaScript in IE 版权:翻译未经过javascript kit同意,我只对我所翻译的中文部分负责。版权归
标签: Web开发
1.最开始web上只有静态的html 2.为了满足更好的交互需求,netscape开发了在Navigator中使用的LiveScript语言,后改名为JavaScript 3.Microsoft发行jscript用于internet explorer. 4.最初的jscript和javascript差异过大,web程序员不得不痛苦的为两种浏览器编写两种脚本。于是诞生了ECMAScript,是一种国际标准化的javascr...

经验教程

336

收藏

66
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部