介紹call,callee,caller,apply的區別與應用
1、caller與callee的區別
caller返回一個函數引用,這個函數調用了當前的函數;callee返回正在執行的函數本省的引用,他是arguments的一個屬性
caller返回一個函數的引用,這個函數調用了當前的函數。
使用這個屬性應該注意:
a、這個屬性只有在函數執行時纔有用
b、如果在javascript程序中,函數由頂層調用的,則返回null
functionName.caller:functionName是當前正在執行的函數
var a = function() {
alert(a.caller);
}
var b = function() {
a();
}
b();
上面代碼。b調用了a,那麼a.caller返回的是b的引用
返回:
function(){
a();
}
如果直接調用a(),即頂層調用,就會返回null。
callee返回正在執行的函數本身的引用,他是arguments的一個屬性
使用callee時應注意:
a、這個屬性只有在函數執行時纔有效
b、他有一個length屬性,可以獲取形參的個數,因此可以用來比較形參和實參個數是否相等,系比較arguments.length是否相等。
var a = function() {
alert(arguments.callee);
}
var b = function() {
a();
}
b();
a在b中被調用,但他返回了a的引用,結果如下:
function(){
alert(arguments.callee);
}
2、call與apply的應用與區別
語法:call([thisObj[,arg1[, arg2[, [,.argN]]]]])
語法:apply([thisObj[,argArray]])