DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> Javascript教程:caller函數和callee屬性
Javascript教程:caller函數和callee屬性
編輯:關於JavaScript     

網頁制作poluoluo文章簡介:對於函數來說,caller 屬性只有在函數執行時才有定義。 如果函數是由 Javascript 程序的頂層調用的,那麼 caller 包含的就是 null 。

caller
返回一個對函數的引用,該函數調用了當前函數。

functionName.caller

functionName 對象是所執行函數的名稱。

說明
對於函數來說,caller 屬性只有在函數執行時才有定義。 如果函數是由 Javascript 程序的頂層調用的,那麼 caller 包含的就是 null 。
下面的例子說明了 caller 屬性的用法:

01.function callerDemo() { 02.    if ( arguments.caller) { 03.        var a= callerDemo.caller.toString(); 04.        alert(a); 05.    } else { 06.        alert("this is a top function"); 07.    } 08.} 09.function handleCaller() { 10.    callerDemo(); 11.} 12.handleCaller(); 13.function calleeDemo() { 14.     alert(arguments.callee); 15.} 16.calleeDemo();

=====================================================================

callee

返回正被執行的 Function 對象,也就是所指定的 Function 對象的正文。

[function.]arguments.callee
可選項 function 參數是當前正在執行的 Function 對象的名稱。

說明

callee 屬性的初始值就是正被執行的 Function 對象。

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

示例

01.//callee可以打印其本身 02.function calleeDemo() { 03.     alert(arguments.callee); 04.} 05.//用於驗證參數 06.function calleeLengthDemo(arg1, arg2) { 07.    if (arguments.length==arguments.callee.length) { 08.         window.alert("驗證形參和實參長度正確!"); 09.        return; 10.     } else { 11.         alert("實參長度:" +arguments.length); 12.         alert("形參長度: " +arguments.callee.length); 13.     } 14.} 15.//遞歸計算 16.var sum = function(n){ 17.  if (n < = 0)                        18.  return 1; 19.  else 20.    return n +arguments.callee(n - 1) 21.}

比較一般的遞歸函數:

1.var sum = function(n){ 2.    if (1==n) return 1; 3.else return n + sum (n-1);

調用時:alert(sum(100));
其中函數內部包含了對sum自身的引用,函數名僅僅是一個變量名,在函數內部調用sum即相當於調用
一個全局變量,不能很好的體現出是調用自身,這時使用callee會是一個比較好的方法。

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved