JavaScript中通过arguments对象实现对象的重载
Posted ldxsuanfa
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JavaScript中通过arguments对象实现对象的重载相关的知识,希望对你有一定的参考价值。
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>Insert title here</title> <script type="text/javascript"> /* *1.js 中不存在函数的重载 2.js函数定义时候的形參个数,和运行时候时。传递的实參的个数能够不一样。 3.js运行时候。会将真实的參数,封装成组arguments */ function add(a){ return a+10; } var add=new Function("a","return a+10"); //alert(add(5)); function add(num1,num2){ return num1+num2; } var add=new Function("num1","num2","return num1+num2"); alert(add(5,6)); alert(add(5));//这样调用的结果是NaN:由于调用的时后定义的两个參数的函数 //也就是尽管有var的声明。可是javascript中仅仅要变量名称同样。后定义的就会覆盖 //之前定义的=======得出的结论就是js中不存在函数的重载。 //-------------------用arguments对象模拟方法的重载----- //-根据不同的參数个数。调用不同的代码块。最多25个參数 function addNum(){ alert(arguments.length); for(var x=0;x<arguments.length;x++){ alert(arguments[x]); //这个对象仅仅能爱函数体内 } if(arguments.length==1){ return arguments[0]+10; }else if(arguments.length==2){ return arguments[0]+arguments[1]; }else{ return "參数错误。请核对"; } } var value=addNum(10,20,30); alert("函数的返回值:"+value);//结果value的值就是:"參数错误,请核对" //其实,是通过參数的推断。去实现调用不同的函数功能,而且返回不同的值;这样做相似的实现了java中的重载 //可是本质上,js中是没有重载的,同样的变量,在不同的位置出现。若赋值后。必定会覆盖前面声明的变量。当然 //这里面排除掉函数内部的量和函数外部变量的这一种关系。
</script> </head> <body> </body> </html>
以上是关于JavaScript中通过arguments对象实现对象的重载的主要内容,如果未能解决你的问题,请参考以下文章