JavaScript中的方法重载实例

 更新时间:2015年03月16日 11:31:53   投稿:junjie  
这篇文章主要介绍了JavaScript中的方法重载实例,本文直接给出重载实例,需要的朋友可以参考下

.NET里面的方法重载用着的确很方便,哪Javascript里面能不能也哪样做呢?

Javasciprt里面本生是没有方法重载的功能,以前很多人的做法可能是直接少传参数过去,然后在根据参数是否为 “undefined” 未定义来决定怎么处理,从而实现类似方法重载的功能。

例如:

复制代码 代码如下:

var showMessage = function(name,value,id){
    if(id != ”undefined”){
        alert(name+value+id);
    }
    else if(value != ”undefined”){
        alert(name + value);
    }
    else{
        alert(name);
    }
}

showMessage(”哈哈”);
showMessage(”哈哈”,”??”);
showMessage(”哈哈”,”??”,124124);

今天在Ajaxian上面看到了一篇关于Javascript方法重载的写法,它是能过另外一个方法来实现的。

看一下这个代码:

复制代码 代码如下:

// addMethod - By John Resig (MIT Licensed)
function addMethod(object, name, fn){
    var old = object[ name ];
    object[ name ] = function(){
        if ( fn.length == arguments.length ){
         return fn.apply( this, arguments );
     }
     else if ( typeof old == 'function' ){
      return old.apply( this, arguments );
  }
}
};

var UserInfo = function(){
    addMethod(this,”find”,function(){
        alert(”没有参数”);
    });

    addMethod(this,”find”,function(name){
        alert(”传入的参数是一个,叫 ”+name);
    });

    addMethod(this,”find”,function(name,value){
        alert(”传入了两个参数,一个叫 name=”+name+” 一个叫 value=”+value);
    });
};

var userinfo = new UserInfo();
userinfo.find();
userinfo.find('我是谁?');
userinfo.find('某某某','1512412514');


看,这样一来就简单了……

相关文章

  • js实现兼容IE和FF的上下层的移动

    js实现兼容IE和FF的上下层的移动

    本来是很简单的一个功能,可是一开始弄的时候,还有IE能实现,FF总是不能实现,在网上看了半天,也没弄出个所以然,所以在同事的帮忙下,总算弄出来了,浏览器的兼容性考的还是细节上面的东西,所有关于细节的,我会用注释标出来的。
    2015-05-05
  • js表达式与运算符简单操作示例

    js表达式与运算符简单操作示例

    这篇文章主要介绍了js表达式与运算符简单操作,结合实例形式分析了JavaScript表达式与运算符的基本算数运算、逻辑运算、比较运算等相关操作技巧,需要的朋友可以参考下
    2020-02-02
  • JS动态设置页面高度的操作代码

    JS动态设置页面高度的操作代码

    这篇文章主要介绍了JS动态设置页面高度的操作代码,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧
    2024-04-04
  • js打开windows上的可执行文件示例

    js打开windows上的可执行文件示例

    这篇文章主要介绍了js如何打开windows上的可执行文件,需要的朋友可以参考下
    2014-05-05
  • javascript中内置对象Math的介绍及用法案例

    javascript中内置对象Math的介绍及用法案例

    Math对象是一个内置对象,具有数学常数和函数的属性和方法,不是一个函数对象,下面这篇文章主要给大家介绍了关于javascript中内置对象Math的介绍及用法案例的相关资料,需要的朋友可以参考下
    2022-03-03
  • 微信小程序开发之从相册获取图片 使用相机拍照 本地图片上传

    微信小程序开发之从相册获取图片 使用相机拍照 本地图片上传

    本篇文章主要介绍了微信小程序开发之从相册获取图片--使用相机拍照,本地图片上传的相关资料。具有很好的参考价值。下面跟着小编一起来看下吧
    2017-04-04
  • js实现的标题栏新消息闪烁提示效果

    js实现的标题栏新消息闪烁提示效果

    这篇文章主要介绍了js实现的标题栏新消息闪烁提示效果,一些大型网站也会经常用到这个效果,需要的朋友可以参考下
    2014-06-06
  • javascript父子页面通讯实例详解

    javascript父子页面通讯实例详解

    这篇文章主要介绍了javascript父子页面通讯的实现方法,实例分析了javascript针对父子页面通讯的原理与相关实现技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-07-07
  • javascript伸缩型菜单实现代码

    javascript伸缩型菜单实现代码

    这是一款真正的JavaScript伸展收缩型菜单,鼠标放上看一看,是不是很酷?鼠标划出菜单项的时候,背景会伸长。菜单没有加链接,想用的自己加,再美化一下,绝对够个性吧。
    2015-11-11
  • javascript生成大小写字母

    javascript生成大小写字母

    本文给大家分享的是javascript生成大写小写字母的代码,十分的简单实用,主要用到了str.charCodeAt()和 String.fromCharCode()方法,有需要的小伙伴可以参考下。
    2015-07-07

最新评论