js中arguments
arguments
每天一对象,JS天天见,今天我们来看看arguments对象及属性。arguments对象不能显式创建,arguments对象只有函数开始时才可用。函数的 arguments 对象并不是一个数组,访问单个参数的方式与访问数组元素的方式相同。索引 n 实际上是 arguments 对象的 0…n 属性的其中一个参数。
下面的示例演示了 arguments 对象的用法,arguments对象和Function是分不开的。
1
function ArgTest(a, b){
2
var i, s = "The ArgTest function expected ";
3
var numargs = arguments.length; // 获取被传递参数的数值。
4
var expargs = ArgTest.length; // 获取期望参数的数值。
5
if (expargs < 2)
6
s += expargs + " argument. ";
7
else
8
s += expargs + " arguments. ";
9
if (numargs < 2)
10
s += numargs + " was passed.";
11
else
12
s += numargs + " were passed.";
13
s += "\n\n"
14
for (i =0 ; i < numargs; i++){ // 获取参数内容。
15
s += " Arg " + i + " = " + arguments[i] + "\n";
16
}
17
return(s); // 返回参数列表。
18
}
以上是arguments对象,由于和Function对象紧密地联系在一起。也就是说每一个函数都有自己的argument属性。下面我们来看看argument属性:为当前执行的 function 对象返回一个arguments 对象,function 参数是当前执行函数的名称,可以省略。
通过 arguments 属性(相对于Function来说),函数可以处理可变数量的参数。arguments 对象的 length 属性包含了传递给函数的参数的数目。对于arguments 对象所包含的单个参数,其访问方法与数组中所包含的参数的访问方法相同。请看下面的例子:
1
function ArgTest(){
2
var i, s, numargs = arguments.length;
3
s = numargs;
4
if (numargs < 2)
5
s += " argument was passed to ArgTest. It was ";
6
else
7
s += " arguments were passed to ArgTest. They were " ;
8
for (i = 0; i < numargs; i++)
9
{
10
s += arguments[i] + " ";
11
}
12
return(s);
13
}
我们知道每一个对象都有自己的属性,arguments对象也不例外,首先arguments的访问犹如Array对象一样,用0到arguments.length-1来枚举每一个元素。下面我们来看看callee属性,返回正被执行的 Function 对象,也就是所指定的 Function 对象的正文。callee 属性是 arguments 对象的一个成员,仅当相关函数正在执行时才可用。callee 属性的初始值就是正被执行的 Function 对象,这允许匿名的递归函数。
1
function factorial(n){
2
if (n <= 0)
3
return 1;
4
else
5
return n * arguments.callee(n - 1)
6
}
7
print(factorial(3));
8

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18


2

3

4

5

6

7

8

9

10

11

12

13


2

3

4

5

6

7

8

【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· .NET10 - 预览版1新功能体验(一)