JavaScript中使用arguments获得函数传参个数实例
2014-08-27 10:14
716 查看
JS与PHP在函数传参方面有点不同,PHP形参与实参个数要匹配,而JS就灵活多了,可以随意传参,实参比形参少或多都不会报错。
实参比形参多不会报错
function say(a){ alert(a); } say('琼台博客','WEB技术博客');
执行结果
我们再来看看形参比实参多的结果
function say(a,b){ alert('a 的值是 '+a+'\nb 的值是 '+b); } say('琼台博客');
执行结果
a 对应第一个实参“琼台博客”,b 没有对应的实参所以值为undefined
arguments对象
其实有时候我们在程序设计比较复杂的时候并不指定参数个数,都是灵活运用。在函数里有一个数组arguments就是专门存储实参数组的,通过arguments我们就可以知道实参个数以及值。
function arg(){ var str = '总共传了'+arguments.length+'个参数\n'; for(var i=0;i<arguments.length;i++){ str += '第'+(i+1)+'个参数值:'+arguments[i]+'\n'; } alert(str); } arg('琼台博客','PHP博客','WEB技术博客');
执行结果
在以上例子中,我们定义函数arg并没有给它指定形参,而是使用arguments对象接收实参,非常灵活。
比如我们可以利用它来计算出一组数字里最小的数字,不管这组数字有多少个。如以下代码:
function arg(){ var tmp = 0, str = '在 '; for(var i=0;i<arguments.length;i++){ for(var g=0;g<arguments.length;g++){ if(arguments[g]<arguments[i]){ tmp = arguments[g]; } } str += arguments[i]+','; } alert(str.substr(0,str.length-1)+' 里最小的值是 '+tmp); } arg(200,100,59,3500);
执行 200,100,59,3500 四个数对比结果
我们在加入两个数,分别是 5 和 60
function arg(){ var tmp = 0, str = '在 '; for(var i=0;i<arguments.length;i++){ for(var g=0;g<arguments.length;g++){ if(arguments[g]<arguments[i]){ tmp = arguments[g]; } } str += arguments[i]+','; } alert(str.substr(0,str.length-1)+' 里最小的值是 '+tmp); } arg(200,100,59,3500,5,60);
执行 200,100,59,3500,5,60 六个数对比结果
根据两次运算结果,我们发现无论我们传进多少个数字,都能正确比对结果。arguments一般用在实参个数不定的地方,比如上边的例子,你可以传5个数进去比较,也可以传100个数进去比较都可以。
您可能感兴趣的文章:
- js的隐含参数(arguments,callee,caller)使用方法
- js中arguments的用法(实例讲解)
- javascript内置对象arguments详解
- javascript arguments 传递给函数的隐含参数
- javascript arguments使用示例
- js中arguments,caller,callee,apply的用法小结
- javascript 利用arguments实现可变长参数
- javascript中onclick(this)用法介绍
- JS中的this变量的使用介绍
- javascript中this的四种用法
- JavaScript中arguments和this对象用法分析
相关文章推荐
- JavaScript中使用arguments获得函数传参个数实例
- JavaScript中使用arguments获得函数传参个数实例
- JavaScript数组函数unshift、shift、pop、push使用实例
- Effective JavaScript Item 22 使用arguments来创建接受可变参数列表的函数
- javascript实例教程(17) 使用javascript的数学函数
- JavaScript服务器端开发(函数实参对象arguments使用的几个注意事项)
- javascript 不停(setInterval)/延时(setTimeout)函数使用实例
- JavaScript数组函数unshift、shift、pop、push使用实例
- [Effective JavaScript 笔记]第22条:使用arguments创建可变参数的函数
- 每天一个JavaScript实例-使用带有定时器的函数闭包
- JavaScript数组函数unshift、shift、pop、push使用实例
- javascript 不停(setInterval)/延时(setTimeout)函数使用实例
- 使用javascript访问XML数据的实例
- 使用javascript访问XML数据的实例
- 使用较大的 JavaScript 函数
- Asp中IsNumberic() isdate() cdate()函数使用实例
- js入门·循环与判断/利用函数的简单实例/使用对象/列举对象属性的名称
- Javascript实例教程(19) 使用HoTMetal(4)
- Javascript实例教程(19) 使用HoTMetal(1)