caller和callee的區(qū)別介紹及演示結(jié)果
caller
caller返回一個函數(shù)的引用,這個函數(shù)調(diào)用了當前的函數(shù)。
使用這個屬性要注意:
1 這個屬性只有當函數(shù)在執(zhí)行時才有用
2 如果在javascript程序中,函數(shù)是由頂層調(diào)用的,則返回null
functionName.caller: functionName是當前正在執(zhí)行的函數(shù)。
var a = function() {
alert(a.caller);
}
var b = function() {
a();
}
b();
上面的代碼中,b調(diào)用了a,那么a.caller返回的是b的引用,結(jié)果如下:
如果直接調(diào)用a(即a在任何函數(shù)中被調(diào)用,也就是頂層調(diào)用),返回null:
var a = function() {
alert(a.caller);
}
var b = function() {
a();
}
//b();
a();
輸出結(jié)果:
callee
callee放回正在執(zhí)行的函數(shù)本身的引用,它是arguments的一個屬性
使用callee時要注意:
1 這個屬性只有在函數(shù)執(zhí)行時才有效
2 它有一個length屬性,可以用來獲得形參的個數(shù),因此可以用來比較形參和實參個數(shù)是否一致,即比較arguments.length是否等于arguments.callee.length
3 它可以用來遞歸匿名函數(shù)。
var a = function() {
alert(arguments.callee);
}
var b = function() {
a();
}
b();
a在b中被調(diào)用,但是它返回了a本身的引用,結(jié)果如下:
- 關(guān)于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的用法和應(yīng)用場景
- js arguments,jcallee caller用法總結(jié)
- js中arguments,caller,callee,apply的用法小結(jié)
- js的隱含參數(shù)(arguments,callee,caller)使用方法
- js中的caller和callee屬性介紹和例子
- javascript中callee與caller的區(qū)別分析
相關(guān)文章
JS中attr和prop屬性的區(qū)別以及優(yōu)先選擇示例介紹
這篇文章主要介紹了JS中attr和prop屬性的區(qū)別以及優(yōu)先選擇,需要的朋友可以參考下2014-06-06javascript函數(shù)聲明和函數(shù)表達式區(qū)別分析
本文向大家展示了javascript中函數(shù)聲明和函數(shù)表達式的概念及區(qū)別,介紹的非常全面,也很詳盡,這里推薦給大家2014-12-12