久久九九国产无码高清_人人做人人澡人人人爽_日本一区二区三区中文字幕_日韩无码性爱免费

javascript中callee與caller的區(qū)別

時間:2024-10-06 09:45:56 JavaScript 我要投稿
  • 相關推薦

javascript中callee與caller的區(qū)別

  callee

  callee是對象的一個屬性,該屬性是一個指針,指向參數(shù)arguments對象的函數(shù)

  首先我們來寫個階成函數(shù):

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

  從這個函數(shù)中可以看出來,用到了遞歸函數(shù),要是改變了函數(shù)名,里面的函數(shù)名也要隨著改變,這樣很不方便所以我們用callee來試試

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

  我們來分析一下為什么這樣寫:根據callee的定義,可以看出來callee是arguments對象的一個屬性,指向arguments對象的函數(shù),這個函數(shù)就是chen(chen=arguments.callee),這樣解釋應該可以理解了吧。

  caller

  caller是函數(shù)對象的一個屬性,該屬性保存著調用當前函數(shù)的函數(shù)的引用(指向當前函數(shù)的直接父函數(shù))

  先來個例子吧

  function a(){b();};function b(){alert(b.caller);};a(); //結果就是彈出函數(shù)a和內容

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

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

  function b(){alert(b.caller);};

  從這個代碼可以看出b函數(shù)中調用了b函數(shù)名,這樣當函數(shù)名改變時就很不方便,我們需要替換里面的那個b

  前面我們知道用什么方法可以指向當前對象,下面我們就來修改一下:

  (function a(){b();})();function b(){alert(arguments.callee.caller);};

  從代碼中可以看出我們用arguments.callee代替了b函數(shù),所以解決了一下麻煩。。。。。

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

【javascript中callee與caller的區(qū)別】相關文章:

JavaScript中的with關鍵字07-24

在Java中執(zhí)行JavaScript代碼07-14

Javascript中typeof 用法歸納09-27

抽象語法樹在JavaScript中的應用08-18

JavaScript中的三種對象10-24

perl- javascript中class的機制05-03

JavaScript類定義原型方法的兩種實現(xiàn)的區(qū)別07-11

JavaScript中push(),join() 函數(shù)實例詳解09-05

詳解JavaScript中的splice()使用方法08-20

javascript中for/in循環(huán)以及常見的使用技巧06-24