JavaScript 没有函数重载&Arguments对象
2015-07-18 10:02
633 查看
对于学过Java的人来说,函数重载并不是一个陌生的概念,但是javaScript中有函数重载么...接下来我们就进行测试
alert(1,2):
alert(1,2,3):
结果对比发现:第一个运行的结果是NaN,第二个运行的结果正常。
JavaScript中不存在函数重载的现象,当同时出现两个相同的函数名驶,第二个会覆盖第一个.因此alet(1,2)会找第二个函数,但是它是实参中的第三个参数为空,因此结果报了NaN.
那么我们怎么样模仿Java中的函数重载现象呢?这里就要介绍Arguments对象...
根据arguments是一个数组,可以根据他的长度length来判断函数的参数的个数...
<script type="text/javascript"> //JavaScript不存在函数重载现象 var add=function(a,b){ return a+b; } var add=function(a,b,c){ return a+b+c; }
<span style="white-space:pre"> </span>alert(1,2); alert(add(1,2,3)); </script>这个案例也仿照java中的语法,来模拟函数重载..我们运行一下结果
alert(1,2):
alert(1,2,3):
结果对比发现:第一个运行的结果是NaN,第二个运行的结果正常。
JavaScript中不存在函数重载的现象,当同时出现两个相同的函数名驶,第二个会覆盖第一个.因此alet(1,2)会找第二个函数,但是它是实参中的第三个参数为空,因此结果报了NaN.
那么我们怎么样模仿Java中的函数重载现象呢?这里就要介绍Arguments对象...
<script type="text/javascript"> //JavaScript不存在函数重载现象 var add=function(){ if(arguments.length==2){ return arguments[0]+arguments[1]; }else if(arguments.length==3){ return arguments[0]+arguments[1]+arguments[2]; } } alert(add(1,2,4)); </script>functon必须是空的function(){}
根据arguments是一个数组,可以根据他的长度length来判断函数的参数的个数...
相关文章推荐
- JSP页面实现自动跳转
- PHP+Javascript实现在线拍照功能实例
- JavaScript 二级联动
- ExtJs动态生成treepanel的Json格式
- 在<a></a>标签中如何调用javaScript脚本
- classList详解,让你的js方便地操作DOM类
- JavaScript内置对象
- Javascript异步编程的4种方法
- PHP+Javascript实现在线拍照功能实例
- javascript顺序加载图片的方法
- js实现固定显示区域内自动缩放图片的方法
- JavaScript实现模仿桌面窗口的方法
- js实现用户离开页面前提示是否离开此页面的方法(包括浏览器按钮事件)
- javascript实现页面刷新时自动清空表单并选中的方法
- KBEngine HTML5-js插件
- JavaScript 函数重载
- 大熊君说说JS与设计模式之------代理模式Proxy
- 2015.7.17 第八课 课程重点(js语句:条件、循环)
- js面向对象的编程理解
- javascript数据类型