JavaScript函数arguments数组获得实际传参数个数

JavaScript与PHP在函数传参方面有点不同,PHP形参与实参个数要匹配,而JavaScript就灵活多了,可以随意传参,实参比形参少或多都不会报错。

实参比形参多不会报错

function say (a) {
  console.log(a); 
}
 
say('琼台博客', 'WEB技术博客'); // Output: 琼台博客

【爆款云服务器限时促销】
阿里云云服务器ECS实例2核2G,新人专享渠道特惠价只要82元!特惠热卖中。 点击立即购买

我们再来看看形参比实参多的结果

function say (a, b) {
  console.log('a 的值是 '+a+', b 的值是 '+b); 
}
 
say('琼台博客'); // Output: a 的值是 琼台博客, b 的值是 undefined

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]+','; 
  }
  console.log(str);
}
arg('琼台博客', 'www.qttc.net'); // Output: 总共传了2个参数, 第1个参数值:琼台博客, 第2个参数值:www.qttc.net,

在以上例子中,我们定义函数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]+',';
  }
  console.log(str.substr(0,str.length-1)+' 里最小的值是 '+tmp);
}
arg(200,100,59,3500); // Output: 在 200,100,59,3500 里最小值是 59

我们发现无论我们传进多少个数字,都能正确比对结果。arguments一般用在实参个数不定的地方,比如上边的例子,你可以传5个数进去比较,也可以传100个参数进去比较都可以。

分享

TITLE: JavaScript函数arguments数组获得实际传参数个数

LINK: https://www.qttc.net/147-javascript-arguments.html

NOTE: 原创内容,转载请注明出自琼台博客