JS高级学习笔记 —— 073 arguments详解

/*
arguments是什么?
答:是1个对象,是一个长的很像数组的对象。

arguments内容是?
答:arguments是函数运行时的实参列表。
*/

<script type="text/javascript">

// arguments对象的打印       
(function (d,e,f) {
    console.log(arguments);
}) ('hello','world','!');
// Arguments { 0: "hello", 1: "world", 2: "!", … }



// 由于没有与之对应的形参来调用haha,则无法获取
// 但我们可以通过调用arguments来获取任意多个的实参
(function (d,e,f) {
    console.log(arguments[3]);
}) ('hello','world','!','haha'); // haha



// 形参与对应的arguments单元是相互映射的,互相影响
(function (d,e,f) {
    arguments[0] = 'china';
    console.log(d);
}) ('hello','world','!','haha'); // china



// arguments.length获取运行时收到的实参个数(多态可用)       
(function (d,e,f) {
    console.log(arguments.length);
}) ('hello','world','!'); //3



// arguments.callee 属性代表“当前运行的函数”
(function (d,e,f) {
    console.log(arguments.callee);
}) ('hello','world','!'); 



// 不用函数名,匿名函数立即执行完成递归
alert((function t(n) {
    if(n <= 1) {
        return 1;
    } else {
        return n + arguments.callee(n-1);
    }
} )(100)
);

</script>

/*
函数运行体内,关键的三个对象

AO –> 本函数AO上没有某属性,则继续去外层函数的AO上找,直到全局变量. 叫做 作用域链

arguments –> 每个函数有自己的callee,但不向外层接着找arguments的相关属性,即不形成链接
*/

猜你喜欢

转载自blog.csdn.net/dyw_666666/article/details/80137716
073