JavaScript的arguments对象应用示例
2023-06-13 09:15:45 时间
arguments对象
在函数代码中,使用特殊对象arguments,开发者无需明确指出参数名,就能访问它们。
例如,在函数sayHi()中,第一个参数是message。用arguments[0]也可以访问这个值,即第一个参数的值(第一个参数位于位置0,第二个参数位于位置1,依此类推)。
因此,无需明确命名参数,就可以重写函数:
functionsayHi(){ if(arguments[0]=="bye"){ return; } alert(arguments[0]); }
检测参数个数
还可以用arguments对象检测函数的参数个数,引用属性arguments.length即可。
下面的代码将输出每次调用函数使用的参数个数:
functionhowManyArgs(){ alert(arguments.length); } howManyArgs("string",45); howManyArgs(); howManyArgs(12);
上面这段代码将依次显示"2"、"0"和"1"。
注释:与其他程序设计语言不同,ECMAScript不会验证传递给函数的参数个数是否等于函数定义的参数个数。开发者定义的函数都可以接受任意个数的参数(根据Netscape的文档,最多可接受255个),而不会引发任何错误。任何遗漏的参数都会以undefined传递给函数,多余的函数将忽略。
模拟函数重载
用arguments对象判断传递给函数的参数个数,即可模拟函数重载:
functiondoAdd(){ if(arguments.length==1){ alert(arguments[0]+5); }elseif(arguments.length==2){ alert(arguments[0]+arguments[1]); } }
doAdd(10);//输出"15"
doAdd(40,20);//输出"60"
当只有一个参数时,doAdd()函数给参数加5。如果有两个参数,则会把两个参数相加,返回它们的和。所以,doAdd(10)输出的是"15",而doAdd(40,20)输出的是"60"。
虽然不如重载那么好,不过已足以避开ECMAScript的这种限制。
相关文章
- javascript_JavaScript走向成熟
- JavaScript——流程控制
- JavaScript循环
- JavaScript 函数
- 检测设备平台,操作系统,方向 Javascript 库:Device.js
- javascript ios 拍照照片翻转解决方案详解编程语言
- JavaScript事件列表解说
- Javascript更新JavaScript数组的uniq方法
- JavaScript读取中文cookie时的乱码问题的解决方法
- JavaScript对Cookie操作的封装小结
- JavaScript中SQL语句的应用实现
- JavaScript设计模式富有表现力的Javascript(一)
- JavaScript对象、属性、事件手册集合方便查询
- javascript中callee与caller的用法和应用场景
- JavaScript动态调整TextArea高度的代码
- javascript针对DOM的应用分析(四)
- javascript的字符串按引用复制和传递,按值来比较介绍与应用
- javascript中parentNode,childNodes,children的应用详解
- javascript数组操作总结和属性、方法介绍
- JavaScript实现班级随机点名小应用需求的具体分析
- javascript实现分栏显示小技巧附图
- JavaScript中的eval()函数使用介绍
- javascript实现滑动解锁功能
- Javascript拖拽的一些简单的应用(逐行分析代码,让你轻松了拖拽的原理)