日期:2014-05-16  浏览次数:20392 次

JS arguments 对象 (JS方法可变参数及模拟函数重载)

arguments 对象

在函数代码中,使用特殊对象 arguments,开发者无需明确指出参数名,就能访问它们。

?

function a(x,y,z){
	  console.log(arguments[0])   //表示第一个参数x
	  console.log(arguments[1])  //表示第一个参数y
      console.log(arguments[2])   //表示第三个参数,前提是在调用函数时传入了三个参数 
      console.log(arguments.length)  //表示实际传入参数的个数
      arguments.callee(1,2,3)   //调用自身 
}

?

模拟函数重载

用 arguments 对象判断传递给函数的参数个数,即可模拟函数重载:

function doAdd() {
  if(arguments.length == 1) {
    alert(arguments[0] + 5);
  } else if(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 的这种限制。