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

javascript arguments使用示例

 更新時(shí)間:2014年12月16日 10:46:33   投稿:hebedich  
這篇文章主要通過一個(gè)實(shí)例,簡(jiǎn)單介紹了javascript arguments使用方法,小伙伴們參考下。

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

<script Language="JavaScript">
//第一個(gè)參數(shù)值.
function test(a,b,c,d){
  alert(arguments[0]);
}
//arguments[0]實(shí)際上就是a,同理,arguments[1]就是b,依次c,d
</script>

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

 <script Language="JavaScript">
{
    function function_Name(exp1,exp2,exp3,exp4)
    {
        var umber="";
        umber=arguments.length;
        alert(umber);
    }
            function_Name('a','b','c','d');         都可以調(diào)用
        //    function_Name("a","b","c","d");     都可以調(diào)用
}
</script>

1、在JavaScript中,arguments對(duì)象是比較特別的一個(gè)對(duì)象,實(shí)際上是當(dāng)前函數(shù)的一個(gè)內(nèi)置屬性。arguments非常類似Array,但實(shí)際上又不是一個(gè)Array實(shí)例??梢酝ㄟ^如下代碼得以證實(shí)(當(dāng)然,實(shí)際上,在函數(shù)funcArg中,調(diào)用arguments是不必要寫成funcArg.arguments,直接寫arguments即可)。

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

 Array.prototype.testArg = "test";
 function funcArg() {
     alert(funcArg.arguments.testArg); 
     alert(funcArg.arguments[0]);
 }
 alert(new Array().testArg); // result: "test"
 funcArg(10);                // result: "undefined"  "10"

2、arguments對(duì)象的長(zhǎng)度是由實(shí)參個(gè)數(shù)而不是形參個(gè)數(shù)決定的。形參是函數(shù)內(nèi)部重新開辟內(nèi)存空間存儲(chǔ)的變量,但是其與arguments對(duì)象內(nèi)存空間并不重疊。對(duì)于arguments和值都存在的情況下,兩者值是同步的,但是針對(duì)其中一個(gè)無值的情況下,對(duì)于此無值的情形值不會(huì)得以同步。如下代碼可以得以驗(yàn)證。

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

 function f(a, b, c){
     alert(arguments.length);   // result: "2"
     a = 100;
     alert(arguments[0]);       // result: "100"
     arguments[0] = "qqyumidi";
     alert(a);                  // result: "qqyumidi"
     alert(c);                  // result: "undefined"
     c = 2012;
     alert(arguments[2]);       // result: "undefined"
 }
 f(1, 2);

3、由JavaScript中函數(shù)的聲明和調(diào)用特性,可以看出JavaScript中函數(shù)是不能重載的。

根據(jù)其他語言中重載的依據(jù):"函數(shù)返回值不同或形參個(gè)數(shù)不同",我們可以得出上述結(jié)論:

第一:Javascript函數(shù)的聲明是沒有返回值類型這一說法的;

第二:JavaScript中形參的個(gè)數(shù)嚴(yán)格意義上來講只是為了方便在函數(shù)中的變量操作,實(shí)際上實(shí)參已經(jīng)存儲(chǔ)在arguments對(duì)象中了。

另外,從JavaScript函數(shù)本身深入理解為什么JavaScript中函數(shù)是不能重載的:在JavaScript中,函數(shù)其實(shí)也是對(duì)象,函數(shù)名是關(guān)于函數(shù)的引用,或者說函數(shù)名本身就是變量。對(duì)于如下所示的函數(shù)聲明與函數(shù)表達(dá)式,其實(shí)含以上是一樣的(在不考慮函數(shù)聲明與函數(shù)表達(dá)式區(qū)別的前提下),非常有利于我們理解JavaScript中函數(shù)是不能重載的這一特性。

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

 function f(a){
     return a + 10;
 }
 function f(a){
     return a - 10;
 }
 // 在不考慮函數(shù)聲明與函數(shù)表達(dá)式區(qū)別的前提下,其等價(jià)于如下
 var f = function(a){
     return a + 10;
 }
 var f = function(a){
     return a - 10;
 }

4、arguments對(duì)象中有一個(gè)非常有用的屬性:callee。arguments.callee返回此arguments對(duì)象所在的當(dāng)前函數(shù)引用。在使用函數(shù)遞歸調(diào)用時(shí)推薦使用arguments.callee代替函數(shù)名本身。

如下:

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

 function count(a){
     if(a==1){
         return 1;
     }
     return a + arguments.callee(--a);
 }
 var mm = count(10);
 alert(mm);

相關(guān)文章

  • js 函數(shù)式編程學(xué)習(xí)筆記

    js 函數(shù)式編程學(xué)習(xí)筆記

    這兩天看書看到了函數(shù)式編程那節(jié),感覺學(xué)到了挺多東西,之前看別人代碼都寫的挺漂亮,現(xiàn)在我寫的代碼是有點(diǎn)亂,所以還是要學(xué)習(xí)下別人的編程模式
    2017-03-03
  • Javascript 實(shí)現(xiàn)放大鏡效果實(shí)例詳解

    Javascript 實(shí)現(xiàn)放大鏡效果實(shí)例詳解

    這篇文章主要介紹了Javascript 實(shí)現(xiàn)放大鏡效果實(shí)例詳解的相關(guān)資料,這里附有實(shí)現(xiàn)實(shí)例代碼,具有參考價(jià)值,需要的朋友可以參考下
    2016-12-12
  • 一文教你如何像導(dǎo)入JS模塊一樣導(dǎo)入CSS

    一文教你如何像導(dǎo)入JS模塊一樣導(dǎo)入CSS

    HTML中通過使用css可以讓網(wǎng)頁(yè)的美觀效果更進(jìn)一步,下面這篇文章主要給大家介紹了如何像導(dǎo)入JS模塊一樣導(dǎo)入CSS的相關(guān)資料,文中給出了詳細(xì)的實(shí)例代碼,需要的朋友可以參考下
    2021-09-09
  • React+Typescript實(shí)現(xiàn)倒計(jì)時(shí)Hook的方法

    React+Typescript實(shí)現(xiàn)倒計(jì)時(shí)Hook的方法

    本文主要介紹了React+Typescript實(shí)現(xiàn)倒計(jì)時(shí)Hook的方法,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • uniapp開發(fā)H5使用formData上傳文件解決方案

    uniapp開發(fā)H5使用formData上傳文件解決方案

    我們很多時(shí)候上傳文件就是使用FormData,然而uniapp默認(rèn)不支持FormData類型數(shù)據(jù)的上傳,下面這篇文章主要給大家介紹了關(guān)于uniapp開發(fā)H5使用formData上傳文件的相關(guān)資料,需要的朋友可以參考下
    2023-12-12
  • JS更改select內(nèi)option屬性的方法

    JS更改select內(nèi)option屬性的方法

    這篇文章主要介紹了JS更改select內(nèi)option屬性的方法,涉及JavaScript動(dòng)態(tài)操作頁(yè)面select元素屬性的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-10-10
  • JavaScript模仿Pinterest實(shí)現(xiàn)圖片預(yù)加載功能

    JavaScript模仿Pinterest實(shí)現(xiàn)圖片預(yù)加載功能

    圖片預(yù)加載是web開發(fā)中一種應(yīng)用相當(dāng)廣泛的技術(shù),比如我們?cè)谧鰣D片翻轉(zhuǎn)顯示等特效的時(shí)候,為了讓圖片在轉(zhuǎn)換的時(shí)候不出現(xiàn)等待,我們最好是先讓圖片下載到本地,然后在繼續(xù)執(zhí)行后續(xù)的操作。今天本文主要介紹的是利用JS模仿Pinterest圖片社交網(wǎng)站的圖片預(yù)加載功能。
    2016-10-10
  • 重學(xué) JS:為啥 await 不能用在 forEach 中詳解

    重學(xué) JS:為啥 await 不能用在 forEach 中詳解

    這篇文章主要介紹了重學(xué) JS:為啥 await 不能用在 forEach 中,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • uniapp自定義彈框的方法

    uniapp自定義彈框的方法

    這篇文章主要為大家詳細(xì)介紹了uniapp自定義彈框的方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-08-08
  • 淺析tr的隱藏和顯示問題

    淺析tr的隱藏和顯示問題

    本篇文章主要是對(duì)tr的隱藏和顯示問題進(jìn)行了詳細(xì)的介紹,需要的朋友可以過來參考下,希望對(duì)大家有所幫助
    2014-03-03

最新評(píng)論