微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

深入解析JavaScript中的arguments对象

arguments定义

所有的函数都有一个自己的arguments对象,用来储存它实际接受到的参数,而不局限于函数声明时所定义的参数列表。它不是数组却类似数组,具有数组一样的访问性质及方式,可以由arguments[n]来访问对应的单个参数的值,并拥有数组长度属性length。但是却不具有数组的一些方法。可以通过call把arguments转化成真正的数组,然后进行数组的操作。

rush:js;"> var args = Array.prototype.slice.call(arguments);

类数组

1. 判断ARGUMENTS是不是数组

rush:js;"> alert(arguments instanceof Array); alert(arguments instanceof Object);

2. 如何严格的判断一个数据是数组(ARRAY)类的实例

rush:js;"> function isArray(value){ if (typeof Array.isArray === "function") { return Array.isArray(value); }else{ return Object.prototype.toString.call(value) === "[object Array]"; } }

3. 把ARGUMENTS转换成数组 方法一:内置的类型可以通过prototype找到内置的属性方法,Array.prototype.slice就是访问Array的内置方法slice。通过slice方法,返回一个数组。call是调用一个对象的方法,以另外一个对象替换当前对象。

rush:js;"> var arg = Array.prototype.slice.call(arguments,0);

方法二:比方法性能要差一点,因为它是先创建一个数组,然后再进行的

rush:js;"> var arg = [].slice.call(arguments,0);

方法三:通过循环转变成数组

rush:js;"> function toArray(arguments){ var a = []; for(var i=0;i

caller

一个函数被另一个函数调用的时候,被调用函数自动生成一个caller属性,指向调用它的函数对象,如果函数未被调用,则caller为null。

rush:js;"> function testCaller() { var caller = testCaller.caller; alert(caller); } function aCaller() { testCaller(); } aCaller();

弹出的是函数aCaller的内容

arguments.callee

arguments.callee指向正在运行的函数自身,返回正被执行的 Function 对象,也就是所指定的 Function 对象的正文。 注意:arguments.length是实参长度,arguments.callee.length是形参长度,通常用来判断形参与实参长度是否一致 通过arguments获得函数的实参,通过arguments.callee获得函数的形参。 在闭包中应用的也比较广泛。

rush:js;"> var i = 0;

function b(num) {

if (num < 10) {

  num++;

  i++;

  //如果有参数,callee也要把参数带上;

  arguments.callee(num);

} else {

  //输出2次

  alert("调用了"+i+"次callee!");

}

}

b(8);

Arguments.callee在闭包中的应用,它提供了一种递归调调用的功能。

//用arguments.callee计算10的阶乘,例如: 1×2×3×4×5×6×7....

function c(x) {

return x > 1 ? x * arguments.callee(x - 1) : 1

} (10);

//输出6

alert(c(3));

//输出3628800

alert(c(10));

例:callee求1-n的和

rush:js;"> function fn(n){ if(n==1) return n; else return n+arguments.callee(n-1); }

它可以让一个匿名函数自己调用自己

例:

rush:js;"> function list(type){ var result = "<"+type+"l>
  • "; var args = Array.prototype.slice.call(arguments,1); result += args.join("
  • "); result += "
  • "; return result; } var listHtml = list("o","one","two"); console.log(listHtml);

    例2:面试题:下面的console.log结果是[1,2,3,4]的是?

    rush:js;"> function foo(x){ console.log(arguments); return x; } foo(1,4); function foo(x){ console.log(arguments); return x; }(1,4)

    在预解释的时候,function fn(){}(1);会被分开处理,分成两个函数,第一个是function fn() {},而第二个则为匿名函数:(1)。如果第二个不带参数,就会报错,但是上面的函数包含在一个()里面,则是正确的。

    rush:js;"> (function fn(){ console.log(arguments); }(1,4)); (function foo(x){ console.log( arguments); return x; })(1,4) function foo(){ bar.apply(null,arguments); } function bar(x){ console.log(arguments); } foo(1,4);

    原文地址:https://www.jb51.cc/js/47951.html

    版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

    相关推荐