如何实现JS函数的重载

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何实现JS函数的重载相关的知识,希望对你有一定的参考价值。

ECMAScript 函数不能像传统意义上那样实现重载。而在其他语言(如 Java)中,可以为一个函数编写两个定义,只要这两个定义的签名(接受的参数的类型和数量)不同即可。如前所述,ECMAScirpt函数没有签名,因为其参数是由包含零或多个值的数组来表示的。而没有函数签名,真正的重载是不可能做到的。


如果在 ECMAScript中定义了两个名字相同的函数,则该名字只属于后定义的函数。请看下面的例子:

function addSomeNumber(num){
    return num + 100;
}
function addSomeNumber(num) {
    return num + 200;
}
var result = addSomeNumber(100); //300

在此,函数 addSomeNumber()被定义了两次。第一个版本给参数加 100,而第二个版本给参数加200。由于后定义的函数覆盖了先定义的函数,因此当在最后一行代码中调用这个函数时,返回的结果就是 300。

如前所述,通过检查传入函数中参数的类型和数量并作出不同的反应,可以模仿方法的重载。

function addSomeNumber(num1) { 
    var num1= arguments.length; 
    if(1 == num1) { 
       var num2= arguments[1]; 
       alert("高为:"+num1+",宽为:"+num2); 
    } else { 
       alert("高为:"+num1); 
    } 
}

 

 

 

个人理解浅薄,欢迎指正!

以后及时补充~


 

【END】

 

以上是关于如何实现JS函数的重载的主要内容,如果未能解决你的问题,请参考以下文章

js面向对象编程:怎样实现方法重载

js重载

导航架构片段重载问题

从两个角度理解为什么 JS 中没有函数重载

原生js函数的伪重载

虚拟赋值运算符重载——如何选择正确的重载函数?