js中的caller和callee屬性介紹和例子
一、caller
返回一個(gè)對(duì)函數(shù)的引用,該函數(shù)調(diào)用了當(dāng)前函數(shù)。
functionName.caller
functionName 對(duì)象是所執(zhí)行函數(shù)的名稱。
說明
對(duì)于函數(shù)來說,caller 屬性只有在函數(shù)執(zhí)行時(shí)才有定義。 如果函數(shù)是由 Javascript 程序的頂層調(diào)用的,那么 caller 包含的就是 null 。
下面的例子說明了 caller 屬性的用法:
function callerDemo() {
if ( arguments.caller) {
var a= callerDemo.caller.toString();
alert(a);
} else {
alert("this is a top function");
}
}
function handleCaller() {
callerDemo();
}
handleCaller();
function calleeDemo() {
alert(arguments.callee);
}
calleeDemo();
二、callee
返回正被執(zhí)行的 Function 對(duì)象,也就是所指定的 Function 對(duì)象的正文。
[function.]arguments.callee
可選項(xiàng) function 參數(shù)是當(dāng)前正在執(zhí)行的 Function 對(duì)象的名稱。
說明
callee 屬性的初始值就是正被執(zhí)行的 Function 對(duì)象。
callee 屬性是 arguments 對(duì)象的一個(gè)成員,它表示對(duì)函數(shù)對(duì)象本身的引用,這有利于匿名函數(shù)的遞歸或者保證函數(shù)的封裝性,例如下邊示例的遞歸計(jì)算1到n的自然數(shù)之和。而該屬性僅當(dāng)相關(guān)函數(shù)正在執(zhí)行時(shí)才可用。還有需要注意的是callee擁有l(wèi)ength屬性,這個(gè)屬性有時(shí)候用于驗(yàn)證還是比較好的。arguments.length是實(shí)參長(zhǎng)度,arguments.callee.length是形參長(zhǎng)度,由此可以判斷調(diào)用時(shí)形參長(zhǎng)度是否和實(shí)參長(zhǎng)度一致。
示例
//callee可以打印其本身
function calleeDemo() {
alert(arguments.callee);
}
//用于驗(yàn)證參數(shù)
function calleeLengthDemo(arg1, arg2) {
if (arguments.length==arguments.callee.length) {
window.alert("驗(yàn)證形參和實(shí)參長(zhǎng)度正確!");
return;
} else {
alert("實(shí)參長(zhǎng)度:" +arguments.length);
alert("形參長(zhǎng)度: " +arguments.callee.length);
}
}
//遞歸計(jì)算
var sum = function(n){
if (n < = 0)
return 1;
else
return n +arguments.callee(n - 1)
}
比較一般的遞歸函數(shù):
var sum = function(n){
if (1==n) return 1;
else return n + sum (n-1);
調(diào)用時(shí):alert(sum(100));
其中函數(shù)內(nèi)部包含了對(duì)sum自身的引用,函數(shù)名僅僅是一個(gè)變量名,在函數(shù)內(nèi)部調(diào)用sum即相當(dāng)于調(diào)用
一個(gè)全局變量,不能很好的體現(xiàn)出是調(diào)用自身,這時(shí)使用callee會(huì)是一個(gè)比較好的方法。
- js的隱含參數(shù)(arguments,callee,caller)使用方法
- javascript中callee與caller的用法和應(yīng)用場(chǎng)景
- js apply/call/caller/callee/bind使用方法與區(qū)別分析
- javascript下arguments,caller,callee,call,apply示例及理解
- javascript中callee與caller的區(qū)別分析
- js中arguments,caller,callee,apply的用法小結(jié)
- 理解Javascript的caller,callee,call,apply區(qū)別
- Javascript - 全面理解 caller,callee,call,apply
- js arguments,jcallee caller用法總結(jié)
- javascript中caller和callee詳解
- JavaScript中callee和caller的區(qū)別與用法實(shí)例分析
相關(guān)文章
客戶端腳本中常常出現(xiàn)的一些問題和調(diào)試技巧
客戶端腳本中常常出現(xiàn)的一些問題和調(diào)試技巧...2007-01-01
JavaScript學(xué)習(xí)筆記整理_用于模式匹配的String方法
下面小編就為大家?guī)硪黄狫avaScript學(xué)習(xí)筆記整理_用于模式匹配的String方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-09-09
window.location.reload 刷新使用分析(去對(duì)話框)
這篇文章主要介紹了window.location.reload 刷新使用分析(去對(duì)話框),需要的朋友可以參考下2015-11-11
slice函數(shù)的用法 之不錯(cuò)的應(yīng)用
slice函數(shù)的用法 之不錯(cuò)的應(yīng)用...2006-12-12

