JS隐蔽函数 arguments的用法

本文是本渣在看了JS中函数arguments的用法以后,写的一些东西,希望能协助到人人。

1.arguments对象

在JavaScript中,arguments对象是比较迥殊的一个对象,实际上是当前函数的一个内置属性。arguments异常相似Array,但实际上又不是一个Array实例。能够经由过程以下代码得以证明(固然,实际上,在函数funcArg中,挪用arguments是不必要写成funcArg.arguments,直接写arguments即可,此处为了让人人看邃晓)。

Array.prototype.testArg = "shuzu";
function funcArg() {
    alert(funcArg.arguments.testArg);  
    alert(funcArg.arguments[0]);
}

alert(new Array().testArg); // result: "shuzu"
funcArg(10);                // result: "undefined"  "10"

输出效果是 :
shuzu
undefined
10
我们能够看到arguments的范例并没有数组的testArg属性。同时arguments的用法和数组有点相似,argument[0]和array[0]一样,示意第一个对象。(ps:这里的prototype的作用是给某个对象加上某种属性,不懂的小伙伴能够去w3school看看引见。)

2.callee

arguments对象中有一个异常有效的属性:callee。arguments.callee返回此arguments对象地点的当前函数援用。在运用函数递归挪用时引荐运用arguments.callee替代函数名自身。

var fibonacci =function(n) {
    return n <2? n : arguments.callee(n -1) + arguments.callee(n -2);
}; //斐波纳挈数列求值

3.called

此属性的作用简朴的说 就是返回挪用该函数的函数,也就是function test1(){ test2();} 只要在test2是被test1函数挪用,test2.called才有意义。假如test2是在函数顶部被挪用,则test2.called返回null.
假如在字符串高低文中运用 caller属性,那末效果和 functionName.toString 一样,也就是说,显现的是函数的反编译文本,

function callerDemo() {
    if (callerDemo.caller) {
        var a= callerDemo.caller.toString();
          alert(a);
      } else {
          alert("this is a top function");
      }
}
function handleCaller() {
      callerDemo();
}
handlecaller();
callerDemo();

输出效果:

function handleCaller() {
      callerDemo();
}
this is a top function
    原文作者:mcgrady
    原文地址: https://segmentfault.com/a/1190000004587626
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞