如何实现JS函数的重载

2016-02-19 12:00 5 1 收藏

清醒时做事,糊涂时读书,大怒时睡觉,无聊时关注图老师为大家准备的精彩内容。下面为大家推荐如何实现JS函数的重载,无聊中的都看过来。

【 tulaoshi.com - Web开发 】

javascript不能支持函数的重载,如下:
代码如下:

script language="JavaScript"
function f(length)
{
    alert("高为:"+length);
}

function f(length,width)
{
    alert("高为:"+length+",宽为:"+width);
}
/srcipt

上面那段代码其实是行不通的,因为函数定义时的参数个数和函数调用时的参数个数没有任何关系。 在函数中可以用f.arguments[0]和f.arguments[1]得到调用时传入的第一和第二个参数,所以定义function(length),后面用f(10,10)调用是没有问题的。所以在上面这段代码中,第二个函数是永远不可能被调用到的,那么,要怎样才能实现像函数重载那样的功能呢?
    那就是在函数定义中用f.arguments.length判断一下调用时传入的参数个数。然后对不同的情况采用不同的处理方式。
如下:
代码如下:

script language="JavaScript"
function f()
{
    var len= arguments.length;
    if(1 == len)
    {
        var length = arguments[0];
        var width = arguments[1];
        f2(length,width);
    }
    else
    {
        var length = arguments[0];
        f1(length);
    }
}

function f1(length)
{
    alert("高为:"+length);
}

function f2(length,width)
{
    alert("高为:"+length+",宽为:"+width);
}
/srcipt

这样,你就可以给函数f()传入一个参数也可以传入两个参数了,比如f(10)和f(10,10);
    个人觉得,这样虽然可以实现重载,但也不是很好用,我们可以根据具体情况在一个函数中实现重载,如果要重载的两个函数相差较大,那就保留两个函数,而如果两个函数的实现基本差不多,那么可以在一个函数中进行判断,处理不同的部分,而不需要像上面那样写成三个函数,如下:
代码如下:

script language="JavaScript"
function f(length)
{
    var len= arguments.length;
    if(1 == len)
    {
        var width = arguments[1];
        alert("高为:"+length+",宽为:"+width);
    }
    else
    {
        alert("高为:"+length);
    }
}
/srcipt

来源:https://www.tulaoshi.com/n/20160219/1599438.html

延伸阅读
    重载函数(overloaded function)是C++支持的一种特殊函数,C++编译器对函数重载的判断更是C++语言中最复杂的内容之一   首先我们先明确一下重载函数的定义:在相同的声明域中的函数名相同的,而参数表不同的,即通过函数的参数表而唯一标识并且来区分函数的一种特殊的函数。   您也许要问,函数为什么要重载呢...
标签: Web开发
?     function phpescape($str)  {           $sublen=strlen($str);           $retrunString="";           for ($i=0;$i$sublen;$i++)&...
标签: Web开发
代码如下: function map(a,f){f(a);} function getRand(a,b) {     if(a)     {         b=b?b:0;         return Math.floor(Math.random()*a+b);     }else  &...
  函数重载是用来描述同名函数具有相同或者相似功能,但数据类型或者是参数不同的函数治理操作的称呼。 !-- frame contents -- !-- /frame contents -- 我们来举一个实际应用中的例子来说明问题:我们要进行两种不同数据类型的和操作为了实现它,在c语言中我们就要写两个不同名称的涵数来进行区分例...
标签: Web开发
 //   排序:向上移动      function   Up()      ...{        var   sel=document.getElementById("selectCheck");  //获取select      var  &nb...

经验教程

362

收藏

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