JavaScript中使用arguments获得函数传参个数实例
作者:bea
JS与PHP在函数传参方面有点不同,PHP形参与实参个数要匹配,而JS就灵活多了,可以随意传参,实参比形参少或多都不会报错。 实参比形参多不会报错 function say(a){alert(a); }say('琼台博客','WEB技术博客'); 执行结果 我们再来看看形参比实参多的结果 function say(a,b){alert('a 的值是 '+a+'b 的值是 '+b); }say('琼台博客'); 执行结果 a 对应第一个实参“琼台博客”,b 没有
JS与PHP在函数传参方面有点不同,PHP形参与实参个数要匹配,而JS就灵活多了,可以随意传参,实参比形参少或多都不会报错。
实参比形参多不会报错
function say(a){
alert(a);
}
say('琼台博客','WEB技术博客');
执行结果
我们再来看看形参比实参多的结果
function say(a,b){
alert('a 的值是 '+a+'
b 的值是 '+b);
}
say('琼台博客');
执行结果
a 对应第一个实参“琼台博客”,b 没有对应的实参所以值为undefined
arguments对象
其实有时候我们在程序设计比较复杂的时候并不指定参数个数,都是灵活运用。在函数里有一个数组arguments就是专门存储实参数组的,通过arguments我们就可以知道实参个数以及值。
function arg(){
var str = '总共传了'+arguments.length+'个参数
';
for(var i=0;i<arguments.length;i++){
str += '第'+(i+1)+'个参数值:'+arguments[i]+'
';
}
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个数进去比较都可以。
有用 | 无用
实参比形参多不会报错
function say(a){
alert(a);
}
say('琼台博客','WEB技术博客');
执行结果
我们再来看看形参比实参多的结果
function say(a,b){
alert('a 的值是 '+a+'
b 的值是 '+b);
}
say('琼台博客');
执行结果
a 对应第一个实参“琼台博客”,b 没有对应的实参所以值为undefined
arguments对象
其实有时候我们在程序设计比较复杂的时候并不指定参数个数,都是灵活运用。在函数里有一个数组arguments就是专门存储实参数组的,通过arguments我们就可以知道实参个数以及值。
function arg(){
var str = '总共传了'+arguments.length+'个参数
';
for(var i=0;i<arguments.length;i++){
str += '第'+(i+1)+'个参数值:'+arguments[i]+'
';
}
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个数进去比较都可以。
有用 | 无用
猜你喜欢
您可能感兴趣的文章:
- jQuery针对各类元素操作基础教程
- jQuery事件用法实例汇总
- laytpl 精致巧妙的JavaScript模板引擎
- jQuery动画特效实例教程
- jQuery实用函数用法总结
- jQuery实现异步获取json数据的2种方式
- 原生javascript实现的分页插件pagenav
- JavaScript判断变量是对象还是数组的方法
- 分享一个自己动手写的jQuery分页插件
- jQuery标签替换函数replaceWith()的使用例子
- jQuery焦点图切换简易插件制作过程全纪录
- javascript正则表达式参数/g与/i及/gi的使用指南
- JavaScript数组函数unshift、shift、pop、push使用实例
- JavaScript实现的in_array函数
- JavaScript AJAX之惰性载入函数
- IE浏览器不支持getElementsByClassName的解决方法
- JavaScript中使用stopPropagation函数停止事件传播例子
- JavaScript闭包函数访问外部变量的方法
- JavaScript中switch判断容易犯错的一个细节