搞清arguments、arguments.callee、arguments.caller的关系和区别.md

arguments、arguments.callee、arguments.caller的关系和区别

看高三教程的时候(P177),一段代码中用到了arguments.callee来调用函数自生,书中介绍到 “是一个指向正在执行的函数的指针,可以用它来实现对函数的递归调用。”

这段递归调用代码如下:

function factorial (num) {
            if (num <= 1) {
                return 1;
            } else {
                return num * arguments.callee(num - 1);
            }
        }

        var num =  factorial(10);
        console.log(num); // => 3628800

很简单的一段代码。于是自己为了搞清楚知识点,加强自身JS基础,就自己查了下文档

  • arguments
  • arguments.callee
  • arguments.caller

三者的关系与区别:

arguments:

在函数调用时, 会自动在该函数内部生成一个名为 arguments的隐藏对象。 该对象类似于数组, 但又不是数组。可以使用[]操作符获取函数调用时传递的实参。

arguments对象不是一个 Array 。它类似于数组,但除了 长度之外没有任何数组属性。
没错它是个对象!并且它存储的是实际传递给函数的参数

  function obj(){
               //利用instanceof判断arguments
               console.log( 'arguments instanceof Array? ' + (arguments instanceof Array) ); // => false
               console.log( 'arguments instanceof Object? ' + (arguments instanceof Object) ); // => true
               console.log(arguments); // => []内有很多属性其中包括 callee
           }
           obj();
(function () {  
    alert(arguments instanceof Array); // => false  
    alert(typeof(arguments)); // => object  
})();  

By The Way:

typeof 是一元运算符,返回值为字符串,该字符串用来说明运算数的数据类型
用来获取运算数的数据类型。返回的值有number、boolean、undefined、function、object、string

instanceof 用于判断某个变量是否是某个对象的实例,返回值为true或false


接下来,我们修改上面的代码,在调用obj函数时,给它传递参数,但obj函数自己却是没有参数的。

function obj(){
               console.log( 'arguments instanceof Array? ' + (arguments instanceof Array) );
               console.log( 'arguments instanceof Object? ' + (arguments instanceof Object) );
               console.log(arguments);
           }
           //向obj传递参数
           obj('monkey','love',24); 
           // => [3]
           // 0: "monkey"
           // 1: "love"
           // 2: "24"

所以我们说为什么 arguments 是存储的实际传递给函数的参数呢,而不是函数声明的参数。

只有函数被调用时,arguments对象才会创建,未调用时其值为null:



caller 是?

在一个函数A 调用另一个函数B时,被调用函数B会自动生成一个caller属性,指向调用它的函数对象即函数A。如果该函数A当前未被调用,则caller为null。

function testCaller() {  
    var caller = testCaller.caller;  
    alert(caller);  
}  
  
function aCaller() {  
    testCaller();  
}  
  
aCaller();  
// 最终结果输出 =>  function aCaller() {  
           //          testCaller();  
          //          }  主调函数自己


callee 是?

callee是arguments对象的一个成员,它的值为“正被执行的Function对象”。就像第一个demo的代码所显示的一样

function aCallee(arg) {  
  alert(arguments.callee);  
}  
  
function aCaller(arg1, arg2) {
    aCallee();
}  
  
aCaller();  
//  最终结果输出 =>   function aCallee(arg) {  
       //                  alert(arguments.callee);  
        //              }  
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 195,653评论 5 462
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 82,321评论 2 373
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 142,833评论 0 324
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,472评论 1 266
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,306评论 4 357
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,274评论 1 273
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,658评论 3 385
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,335评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,638评论 1 293
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,697评论 2 312
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,454评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,311评论 3 313
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,699评论 3 299
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,986评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,254评论 1 251
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,647评论 2 342
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,847评论 2 335

推荐阅读更多精彩内容

  • 第5章 引用类型(返回首页) 本章内容 使用对象 创建并操作数组 理解基本的JavaScript类型 使用基本类型...
    大学一百阅读 3,196评论 0 4
  • 本章内容 使用对象 创建并操作数组 理解基本的 JavaScript 类型 使用基本类型和基本包装类型 引用类型的...
    闷油瓶小张阅读 674评论 0 0
  • 本文档内容参考 《JavaScript 闯关记》之函数 函数是一段代码,它只定义一次,但可以被执行或调用任意次。在...
    穿越人海遇见你阅读 990评论 0 1
  • 睡意不浓 难得月色如此明艳 连铁窗都似泛起白光 帘外微风 这几日都如此 如若没有城市灯火 这定是个温柔的夜晚
    苏菲1990阅读 153评论 0 1
  • 1.七点钟早起去摆摊,今天只有早场,八点四十多就没太多人了,所以提前收工。 值得记下的事: 虽然说有预感今天去了也...
    文建伟CZYH阅读 340评论 0 1