caller和callee的區(qū)別介紹及演示結果
caller
caller返回一個函數的引用,這個函數調用了當前的函數。
使用這個屬性要注意:
1 這個屬性只有當函數在執(zhí)行時才有用
2 如果在javascript程序中,函數是由頂層調用的,則返回null
functionName.caller: functionName是當前正在執(zhí)行的函數。
var a = function() {
alert(a.caller);
}
var b = function() {
a();
}
b();
上面的代碼中,b調用了a,那么a.caller返回的是b的引用,結果如下:

如果直接調用a(即a在任何函數中被調用,也就是頂層調用),返回null:
var a = function() {
alert(a.caller);
}
var b = function() {
a();
}
//b();
a();
輸出結果:

callee
callee放回正在執(zhí)行的函數本身的引用,它是arguments的一個屬性
使用callee時要注意:
1 這個屬性只有在函數執(zhí)行時才有效
2 它有一個length屬性,可以用來獲得形參的個數,因此可以用來比較形參和實參個數是否一致,即比較arguments.length是否等于arguments.callee.length
3 它可以用來遞歸匿名函數。
var a = function() {
alert(arguments.callee);
}
var b = function() {
a();
}
b();
a在b中被調用,但是它返回了a本身的引用,結果如下:

- 關于arguments,callee,caller等的測試
- Javascript - 全面理解 caller,callee,call,apply
- 理解Javascript的caller,callee,call,apply區(qū)別
- 理解JavaScript的caller,callee,call,apply
- js apply/call/caller/callee/bind使用方法與區(qū)別分析
- javascript下arguments,caller,callee,call,apply示例及理解
- javascript中callee與caller的用法和應用場景
- js arguments,jcallee caller用法總結
- js中arguments,caller,callee,apply的用法小結
- js的隱含參數(arguments,callee,caller)使用方法
- js中的caller和callee屬性介紹和例子
- javascript中callee與caller的區(qū)別分析
相關文章
JS中attr和prop屬性的區(qū)別以及優(yōu)先選擇示例介紹
這篇文章主要介紹了JS中attr和prop屬性的區(qū)別以及優(yōu)先選擇,需要的朋友可以參考下2014-06-06

