當前位置:才華齋>設計>網頁設計>

javascript中callee與caller的區別

網頁設計 閱讀(1.27W)

callee

javascript中callee與caller的區別

callee是物件的一個屬性,該屬性是一個指標,指向引數arguments物件的函式

首先我們來寫個階成函式:

function chen(x){if (x<=1) {return 1;} else{return x*chen(x-1);};};

從這個函式中可以看出來,用到了遞迴函式,要是改變了函式名,裡面的.函式名也要隨著改變,這樣很不方便所以我們用callee來試試

function chen(x){if (x<=1) {return 1;}else{return x*ee(x-1);};};

我們來分析一下為什麼這樣寫:根據callee的定義,可以看出來callee是arguments物件的一個屬性,指向arguments物件的函式,這個函式就是chen(chen=ee),這樣解釋應該可以理解了吧。

caller

caller是函式物件的一個屬性,該屬性儲存著呼叫當前函式的函式的引用(指向當前函式的直接父函式)

先來個例子吧

function a(){b();};function b(){alert(er);};a(); //結果就是彈出函式a和內容

我們來解釋一下吧,首先函式b的屬性caller呼叫當前函式b的函式引用a(就是指向當前函式b的父函式a),所以結果就是彈出 function a(){ b();};

那麼瞭解了caller和callee,那麼可以不可以將二者結合在一起來使用呢

function b(){alert(er);};

從這個程式碼可以看出b函式中呼叫了b函式名,這樣當函式名改變時就很不方便,我們需要替換裡面的那個b

前面我們知道用什麼方法可以指向當前物件,下面我們就來修改一下:

(function a(){b();})();function b(){alert(er);};

從程式碼中可以看出我們用ee代替了b函式,所以解決了一下麻煩。。。。。

以上所述就是本文的全部內容了,希望大家能夠喜歡。