caller:返回一個對調(diào)用function函數(shù)的函數(shù)的引用(用法:function.caller)
說明:對于函數(shù)來說,caller屬性只有在函數(shù)執(zhí)行時才有定義。如果函數(shù)由頂層調(diào)用,caller則為null。
例子分析:第一次handleCaller運(yùn)行的時候,兩個alert返回的都是null,alert(handleCaller.caller)返回null是因為它是由頂層調(diào)用, alert(caller.caller)返回null是因為caller的默認(rèn)值是null。接下去caller()函數(shù)被調(diào)用,caller.caller返回的是調(diào)用它的函數(shù)(handleCaller)的引用,通過caller.caller()可以再次調(diào)用handleCaller函數(shù)。第二次handleCaller運(yùn)行的時候,alert(handleCaller.caller)返回的是caller代碼(其實就是caller的引用),alert(caller.caller)返回的是handleCaller代碼。因為函數(shù)之間的調(diào)用關(guān)系是handleCaller->caller->handleCaller。之后就不斷在2個函數(shù)之間交替執(zhí)行。
caller指向調(diào)用當(dāng)前函數(shù)的函數(shù),但是有一點(diǎn),如果是在全局作用域內(nèi)(即頂層window)被調(diào)用,則返回null。
代碼走起
在全局調(diào)用
testCaller(); // accessed at global
在一個函數(shù)中調(diào)用
此時,testCaller.caller指向就是 function a
callee:返回相對應(yīng)的arguments的函數(shù)引用。(多用于匿名函數(shù)遞歸)
說明:也許你在網(wǎng)上看到最多的是callee返回正在執(zhí)行的函數(shù)引用。我是這么理解,每個函數(shù)都有一個自己的arguments,通常是用來存放參數(shù)的。arguments有一個callee 屬性,初始值就是對應(yīng)自身的函數(shù)引用。當(dāng)你函數(shù)執(zhí)行到該語句時,arguments是默認(rèn)對應(yīng)的是你現(xiàn)在執(zhí)行的函數(shù),那么arguments.callee為當(dāng)前正在執(zhí)行的函數(shù)的引用。當(dāng)然如果你有標(biāo)記過其他函數(shù)的arguments(例子中的args),自然可以用args.callee()去再次調(diào)用那個函數(shù)。
例子分析:例子中的arguments.callee都是默認(rèn)返回當(dāng)前正在執(zhí)行的函數(shù)的引用(a中返回a自身函數(shù)引用,c中返回c自身函數(shù)引用),而通過用args存放a函數(shù)的arguments,在內(nèi)置函數(shù)c中使用args.callee()再次調(diào)用a函數(shù)。
這是一個極簡的遞歸,運(yùn)行結(jié)果正常。
再看看下面的調(diào)用方法
原因也簡單,b=a,b=function a(){};在b調(diào)用之前,我們用了a=null。所以在 function a 運(yùn)行的時候,其中的return x + a(x-1);中的a,指向的就是null,而不是 function a。
所以就報錯了,如何解決這樣的問題。我們將a換一種寫法
再調(diào)用
原因:雖然我們將a=null了,但是函數(shù)a中并沒有用到a,而是通過arguments.callee指向當(dāng)前函數(shù)。
因為arguments.callee的定義就是:返回正在執(zhí)行的函數(shù)。
聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com