首頁  >  文章  >  web前端  >  js中的caller和callee屬性介紹和範例_基礎知識

js中的caller和callee屬性介紹和範例_基礎知識

WBOY
WBOY原創
2016-05-16 16:45:351778瀏覽

一、caller

傳回一個對函數的引用,該函數呼叫了當前函數。

functionName.caller

functionName 物件是所執行函數的名稱。

說明

對函數來說,caller 屬性只有在函數執行時才有定義。 如果函數是由 Javascript 程式的頂層呼叫的,那麼 caller 包含的就是 null 。

下面的例子說明了 caller 屬性的用法:

複製程式碼 代碼如下:

function callerDemo() {
 caller) {
        var a= callerDemo.caller.toString();
        alert(a); 🎜>    }
}
function handleCaller() {
    callerDemo();
}
handleCaller();
function calleeDemo() {
> }
calleeDemo();



二、callee


傳回正被執行的 Function 對象,也就是所指定的 Function 物件的正文。 [function.]arguments.callee

可選項 function 參數是目前正在執行的 Function 物件的名稱。

說明


callee 屬性的初始值就是正被執行的 Function 物件。

callee 屬性是 arguments 物件的一個成員,它表示對函數物件本身的引用,這有利於匿名函數的遞歸或保證函數的封裝性,例如下邊範例的遞歸計算1到n的自然數總和。而該屬性僅當相關函數正在執行時才可用。還有要注意的是callee擁有length屬性,這個屬性有時候用來驗證還是比較好的。 arguments.length是實參長度,arguments.callee.length是形參長度,由此可以判斷調用時形參長度是否和實參長度一致。

範例

複製程式碼

程式碼如下://callee可以列印本身
//callee可以列印本身
     alert(arguments.callee);
}
//用於驗證參數
function calleeLengthDemo(arg1, arg2) {
  .length) {
         window.alert("驗證形參與實參長度正確!");
        return;         alert("形參長度: " arguments.callee.length);
     }
}
//遞歸計算
var sum = f>}
//遞歸計算
var sum = f n   return 1;
  else
   return 1;
  else
   return 1;
  else
  >比較一般的遞迴函數:

複製程式碼 程式碼如下:
var sum = function(n){

    if (1==n) return 1;
else return n sum (n-1);

呼叫時:alert(sum(100));

其中函數內部包含了對sum自身的引用,函數名只是一個變量名,在函數內部調用sum即相當於調用

一個全域變量,不能很好的體現是調用自身,這時使用callee會是比較好的方法。

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn