JScript重载的另类实现

所属分类: 网络编程 / JavaScript 阅读数: 807
收藏 0 赞 0 分享
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是泣红亭" 

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

Node.js事件的正确使用方法

这篇文章主要给大家介绍了关于Node.js事件的正确使用方法,文中通过示例代码介绍的非常详细,对大家学习或者使用Node.js具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
收藏 0 赞 0 分享

微信小程序自定义导航栏实例代码

这篇文章主要给大家介绍了关于微信小程序自定义导航栏的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用微信小程序具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
收藏 0 赞 0 分享

js字符串处理之绝妙的代码

这篇文章主要介绍了js字符串处理之绝妙的代码,包括字符串去重、将字符放在对象中遍历拼接出字符串、把字符串的奇数位和偶数位分别提取到两个数组中、将两个数组按奇数位和偶数位插入拼接为字符串,有时候需要对字符进行处理的时候可以用得到
收藏 0 赞 0 分享

vue设计一个倒计时秒杀的组件详解

这篇文章主要介绍了vue设计一个倒计时秒杀的组件,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
收藏 0 赞 0 分享

详解服务端预渲染之Nuxt(介绍篇)

这篇文章主要介绍了详解服务端预渲染之Nuxt(介绍篇),小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
收藏 0 赞 0 分享

javascrit中undefined和null的区别详解

这篇文章主要介绍了javascrit中undefined和null的区别详解,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
收藏 0 赞 0 分享

浅谈javascript中的prototype和__proto__的理解

这篇文章主要介绍了浅谈javascript中的prototype和__proto__的理解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
收藏 0 赞 0 分享

详解vue中this.$emit()的返回值是什么

这篇文章主要介绍了详解vue中this.$emit()的返回值是什么,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
收藏 0 赞 0 分享

浅谈express.js框架中间件(middleware)

这篇文章主要介绍了浅谈express.js框架中间件(middleware),小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
收藏 0 赞 0 分享

vue自定义指令directive的使用方法

这篇文章主要介绍了vue自定义指令directive的使用方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
收藏 0 赞 0 分享
查看更多