js中arguments的用法
2017-04-05 本文已影响0人
向前冲冲的蜗牛
arguments特性
**arguments **对象不能显式创建, **arguments **对象只有函数开始时才可用。函数的 **arguments **对象并不是一个数组,访问单个参数的方式与访问数组元素的方式相同。索引 n 实际上是 ** arguments **对象的 0…n 属性的其中一个参数。
在javascript中, **不需要明确指出参数名,就能访问它们 **。如:
function hi(){
if(arguments[0]=="andy"){
return;
}
alert(arguments[0]);
}```
##(1)arguments的 length属性##
**含义**
返回调用程序传递给函数的实际参数数目。
**用法**
**[function.]arguments.length**
其中可选项 function 参数是当前正在执行的 Function 对象的名称。
**说明**
当 Function 对象开始执行时,脚本引擎将** arguments** 对象的** length **属性初始化为传递给该函数的**实际参数数目**。
js不会主动为你判断你到底给函数传了多少个参数,如果你多传了,**多余的部分就没有被使用**,**如果你少传了,那么没传的参数值就是undefined**
所以我们可以借助**arguments**的length**属性来检测调用函数时是否使用了正确数目的实际参数**,因为javascript是不会为你做这些事的
##(2)arguments 的 0...n 属性##
**含义**
返回一个** arguments** 对象中的各个参数的实际值,相应的值是由一个正在执行的函数的** arguments**属性返回的。
**用法
[function.]arguments[[0|1|2|...|n]]**
**参数 **
function
可选项。当前正在执行的** Function **对象的名称。
**0, 1, 2, …, n必选项**。0 到 n 范围内的非负整数,其中 0 代表第一个参数而 n 代表最后一个参数。最后参数 n 的值为 arguments.length-1
**说明 **
0 . . . n 属性所返回的值就是**传递给正在执行的函数的实际值**。尽管实际上并不是一个参数数组,您还是可以按照与访问数组元素的方法相同的方式访问组成 arguments 对象的各个参数。
**示例**
下面的例子演示了 arguments 对象的 0 . . . n 属性的用法
function ArgTest(){
var s = "";
s += "The individual arguments are: "
for (n=0; n< arguments.length; n++){
s += ArgTest.arguments[n];
s += " ";
}
return(s);
}
print(ArgTest(1, 2, "hello", new Date()));
##(3)arguments的callee属性##
**含义**
**表示对函数对象本身的引用**,**也就是所指定的 Function 对象的正文**,这有利于实现无名函数的**递归**或者保证**函数的封装性**。
**用法**
**[function.]arguments.callee**
可选项 function 参数是当前正在执行的 Function 对象的名称。
**说明**
**callee **属性是** arguments** 对象的一个成员,仅当相关函数正在执行时才可用。
**callee** 属性的初始值就是正被执行的 Function 对象。这允许匿名的递归函数。
**实例:**
用递归来计算1到n的自然数之和:
<script>
var sum=function(n){
if(1==n) {
return 1;
} else {
return n + arguments.callee(n-1);
}
}
alert(sum(100));
</script>```