caller和callee的區別

caller返回一個函數的引用,這個函數調用了當前的函數;callee放回正在執行的函數本身的引用,它是arguments的一個屬性

caller

caller返回一個函數的引用,這個函數調用了當前的函數。
使用這個屬性要注意:
1 這個屬性只有當函數在執行時纔有用
2 如果在javascript程序中,函數是由頂層調用的,則返回null

functionName.caller: functionName是當前正在執行的函數。


var a = function() { 
	console.log(a.caller); 
} 
var b = function() { 
	a(); 
} 
b();

上面的代碼中,b調用了a,那麼a.caller返回的是b的引用,結果如下:

var b = function() { 
	a(); 
}

如果直接調用a(即a在任何函數中被調用,也就是頂層調用),返回null:

var a = function() { 
	console.log(a.caller); 
} 
var b = function() { 
	a(); 
} 
//b(); 
a();

輸出結果:

null

callee

callee放回正在執行的函數本身的引用,它是arguments的一個屬性
使用callee時要注意:
1 這個屬性只有在函數執行時纔有效
2 它有一個length屬性,可以用來獲得形參的個數,因此可以用來比較形參和實參個數是否一致,即比較arguments.length是否等arguments.callee.length
3 它可以用來遞歸匿名函數。

var a = function() { 
	console.log(arguments.callee); 
} 
var b = function() { 
	a(); 
} 
b();

a在b中被調用,但是它返回了a本身的引用,結果如下:


var a = function() { 
	console.log(arguments.callee); 
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章