欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

js arguments,jcallee caller用法總結(jié)

 更新時(shí)間:2013年11月30日 14:39:22   作者:  
這篇文章主要介紹了js中arguments, jcallee caller用法。需要的朋友可以過(guò)來(lái)參考下,希望對(duì)大家有所幫助

關(guān)鍵字:arguments,callee,caller
arguments:表示傳入函數(shù)的參數(shù)
callee:表示函數(shù)和函數(shù)主體的語(yǔ)句
caller:表示調(diào)用該函數(shù)的函數(shù)

arguments

該對(duì)象代表正在執(zhí)行的函數(shù)和調(diào)用它的函數(shù)的參數(shù)。

caller

返回一個(gè)對(duì)函數(shù)的引用,該函數(shù)調(diào)用了當(dāng)前函數(shù)。
functionName.caller
functionName 對(duì)象是所執(zhí)行函數(shù)的名稱。

說(shuō)明
對(duì)于函數(shù)來(lái)說(shuō),caller屬性只有在函數(shù)執(zhí)行時(shí)才有定義。如果函數(shù)是由頂層調(diào)用的,那么 caller包含的就是 null 。如果在字符串上下文中使用 caller 屬性,那么結(jié)果和functionName.toString一樣,也就是說(shuō),顯示的是函數(shù)的反編譯文本。

callee

返回正被執(zhí)行的 Function 對(duì)象,也就是所指定的Function 對(duì)象的正文。

[function.]arguments.callee

可選項(xiàng) function 參數(shù)是當(dāng)前正在執(zhí)行的 Function 對(duì)象的名稱。

說(shuō)明

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)度一致。

復(fù)制代碼 代碼如下:

<script type='text/javascript'>
function test(x,y,z)
{
alert("實(shí)參長(zhǎng)度:"+arguments.length);
alert("形參長(zhǎng)度:"+arguments.callee.length);
alert("形參長(zhǎng)度:"+test.length);
alert(arguments[ 0 ])        
alert(test[ 0 ])           // undefined 沒(méi)有這種用法

}

//test(1,2,3);
test(1,2,3,4);

/*
*  arguments不是數(shù)組(Array類)
*/
Array.prototype.selfvalue  =   1 ;
function  testAguments() {
    alert( " arguments.selfvalue= " + arguments.selfvalue);
}
alert("Array.sefvalue="+new Array().selfvalue);
testAguments();

/**/ /*
 * 演示函數(shù)的caller屬性.
 * 說(shuō)明:(當(dāng)前函數(shù)).caller:返回一個(gè)對(duì)函數(shù)的引用,該函數(shù)調(diào)用了當(dāng)前函數(shù)
  */

function  callerDemo()  {
     if  (callerDemo.caller)  {
         var  a =  callerDemo.caller.arguments[ 0 ];
        alert(a);
    }   else   {
        alert( " this is a top function " );
    }
}
function  handleCaller()  {
    callerDemo();
}

 callerDemo();
 handleCaller("參數(shù)1","參數(shù)2");


/**/ /*
 * 演示函數(shù)的callee屬性.
 * 說(shuō)明:arguments.callee:初始值就是正被執(zhí)行的 Function 對(duì)象,用于匿名函數(shù)
  */
function  calleeDemo()  {
    alert(arguments.callee);
}
 calleeDemo();
 (function(arg0,arg1){alert("形數(shù)數(shù)目為:"+arguments.callee.length)})();


/**/ /*
 * 演示apply,call函數(shù)的用法
 * 說(shuō)明:作用都是將函數(shù)綁定到另外一個(gè)對(duì)象上去運(yùn)行,兩者僅在定義參數(shù)方式有所區(qū)別:
 *       apply(thisArg,argArray);
 *     call(thisArg[,arg1,arg2…] ]);
 *     即所有函數(shù)內(nèi)部的this指針都會(huì)被賦值為thisArg
  */

  function  ObjectA() {
    alert( " 執(zhí)行ObjectA() " );
    alert(arguments[ 0 ]);
     this .hit = function (msg) {alert(msg)}
     this .info = " 我來(lái)自O(shè)bjectA "
 }

  function  ObjectB() {
    alert( " 執(zhí)行ObjectB() " );
     // 調(diào)用ObjectA()方法,同時(shí)ObjectA構(gòu)造函數(shù)中的所有this就會(huì)被ObjectB中的this替代
    ObjectA.apply( this ,arguments); // ObjectA.call(this);
    alert( this .info);
 }
  ObjectB('參數(shù)0');


  var  value = " global 變量 " ;
  function  Obj() {
     this .value = " 對(duì)象! " ;
 }
  function  Fun1() {
    alert( this .value);
 }
   Fun1();
   Fun1.apply(window);
   Fun1.apply(new Obj());

</script>

相關(guān)文章

  • Web版彷 Visual Studio 2003 顏色選擇器

    Web版彷 Visual Studio 2003 顏色選擇器

    Web版彷 Visual Studio 2003 顏色選擇器...
    2007-01-01
  • JavaScript手寫LRU算法的示例代碼

    JavaScript手寫LRU算法的示例代碼

    LRU是Least?Recently?Used的縮寫,即最近最少使用。作為一種經(jīng)典的緩存策略,它的基本思想是長(zhǎng)期不被使用的數(shù)據(jù),在未來(lái)被用到的幾率也不大,所以當(dāng)新的數(shù)據(jù)進(jìn)來(lái)時(shí)我們可以優(yōu)先把這些數(shù)據(jù)替換掉。本文用JavaScript實(shí)現(xiàn)這一算法,需要的可以參考一下
    2022-09-09
  • JavaScript?中URL?查詢字符串(query?string)的序列與反序列化的方法

    JavaScript?中URL?查詢字符串(query?string)的序列與反序列化的方法

    在 JavaScript 中,可以使用?URLSearchParams?對(duì)象來(lái)處理 URL 中的查詢字符串,這篇文章主要介紹了JavaScript?中URL查詢字符串(query?string)的序列與反序列化,需要的朋友可以參考下
    2023-01-01
  • Three.js GLTF模型加載實(shí)現(xiàn)示例詳解

    Three.js GLTF模型加載實(shí)現(xiàn)示例詳解

    這篇文章主要為大家介紹了Three.js GLTF模型加載實(shí)現(xiàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-04-04
  • 詳解weex默認(rèn)webpack.config.js改造

    詳解weex默認(rèn)webpack.config.js改造

    本篇文章主要介紹了詳解weex默認(rèn)webpack.config.js改造,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-01-01
  • Javascript DOM事件操作小結(jié)(監(jiān)聽鼠標(biāo)點(diǎn)擊、釋放,懸停、離開等)

    Javascript DOM事件操作小結(jié)(監(jiān)聽鼠標(biāo)點(diǎn)擊、釋放,懸停、離開等)

    這篇文章主要介紹了Javascript DOM事件操作,結(jié)合實(shí)例形式總結(jié)分析了javascript監(jiān)聽鼠標(biāo)點(diǎn)擊、釋放,懸停、離開等操作技巧,需要的朋友可以參考下
    2017-01-01
  • JavaScript 對(duì)象、函數(shù)和繼承

    JavaScript 對(duì)象、函數(shù)和繼承

    JavaScript可以說(shuō)是一個(gè)基于對(duì)象的編程語(yǔ)言,為什么說(shuō)是基于對(duì)象而不是面向?qū)ο?,因?yàn)镴avaScript自身只實(shí)現(xiàn)了封裝,而沒(méi)有實(shí)現(xiàn)繼承和多態(tài)。
    2009-07-07
  • JavaScript如何優(yōu)化邏輯判斷代碼詳解

    JavaScript如何優(yōu)化邏輯判斷代碼詳解

    我們?cè)诰帉?JS 代碼時(shí),經(jīng)常會(huì)遇到邏輯判斷復(fù)雜的情況,這篇文章主要給大家介紹了關(guān)于JavaScript如何優(yōu)化邏輯判斷代碼的相關(guān)資料,需要的朋友可以參考下
    2021-06-06
  • webpack css加載和圖片加載的方法示例

    webpack css加載和圖片加載的方法示例

    這篇文章主要介紹了webpack css加載和圖片加載的方法示例,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-09-09
  • JS事件在IE與FF中的區(qū)別詳細(xì)解析

    JS事件在IE與FF中的區(qū)別詳細(xì)解析

    這篇文章主要是對(duì)JS事件在IE與FF中的區(qū)別進(jìn)行了詳細(xì)的分析介紹,需要的朋友可以過(guò)來(lái)參考下,希望對(duì)大家有所幫助
    2013-11-11

最新評(píng)論