在函数默认就有个arguments:他代表这个函数在执行的时候传进来的参数
arguments :实参,实际参数
arguments : 可变参(不定参) 指的是参数的个数是不固定的。
虽然不需要通过形参来传递值,但是如果修改了形参的值,arguments中相应位置上的值也会被修改。
代码片段
function count(a,b,c,d){
//alert(c);
return a+b+c+d;
}
alert(count(1,2,4,5)); //12
alert(count(1,2,3,4)); //10
代码片段
function count(a){ //形参:形式上参数
//arguments : 里面存的是所有实际传进来的参数的集合。
//return arguments.length;
//return arguments[1];
a = 10;
var results = 0;
for(var i=0; i
results += arguments[i];
//results = results + arguments[i];
}
//0 + 1 + 4 + 3 + 10 + 20
return results;
}
alert(count(1,4,3,10,20)); //实参 47
alert(count(1,2)); // 12
alert(count(1,4,3)); //6 0+1+4+3
alert(count(1,2,3,4)); //10 0+1+2+3+4
下面的示例演示了 JavaScript中arguments对象的用法。
function ArgTest(a, b){
var i, s = "The ArgTest function expected ";
var numargs = arguments.length; // 获取被传递参数的数值。
var expargs = ArgTest.length; // 获取期望参数的数值。
if (expargs < 2)
s += expargs + " argument. ";
else
s += expargs + " arguments. ";
if (numargs < 2)
s += numargs + " was passed.";
else
s += numargs + " were passed.";
s += "\n\n"
for (i =0 ; i < numargs; i++){ // 获取参数内容。
s += " Arg " + i + " = " + arguments[i] + "\n";
}
return(s); // 返回参数列表。
}
形参是定义方法的时候,该方法所携带的参数,不如说现在有一个方法
public void printInfo(String info){
System.out.println(info);
}
此处info就是一个形参,它是String类型的。
实参是你在调用方法的时候,给这个方法传递的参数值,比如说有这么一个语句:
**.printInfo("hello");(此处**表示printInfo方法所在类的一个对象),这里的"hello"就是一个实参,实现方法调用的时候,系统会吧实参"hello"的值赋予形参info变量,即info就指向了"hello",调用这个方法后,就会在屏幕上打印输出hello
将函数参数arguments转为数组
1. arguments为什么不是数组?如何证明?
arguments 是没有数组的slice等方法的,所以不是Array类型的。
验证:
function testargs(){
var arr=[1,2,3];
console.log(typeof arguments.slice);
console.log(typeof arr.slice); }
testargs();
输出:
undefined function
当然,还可以通过其他方式来证明,比如说看constructor等等。
2. 如何转为数组?
使用Array的slice方法,如下:
function arg2arr()
{
var arr = Array.prototype.slice.call(arguments);
console.log(arr);
}
arg2arr(1,2,3);
输出:[1,2,3]
还可以写成这样:
Array.prototype.slice.call(arguments, 0)
3. 如何使用原生JS实现自己的slice方法
Array.prototype.slice = function(start,end){
var result = new Array();
start = start || 0;
end = end || this.length; //this指向调用的对象,当用了call后,能够改变this的指向,也就是指向传进来的对象,这是关键
for(var i = start; i < end; i++){ result.push(this[i]); } return result; }
4. JS中有没有toArray方法?如果没有,如何自己实现一个?
var toArray = function(s){
try{
return Array.prototype.slice.call(s);
} catch(e){
var arr = [];
for(var i = 0,len = s.length; i < len; i++){
//arr.push(s[i]);
arr[i] = s[i]; //据说这样比push快
}
return arr;
}
}
【javascript学习指南】Javascript中arguments实参、形参教程
http://m.bbyears.com/jiaocheng/80939.html
推荐访问: