日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 人文社科 > 生活经验 >内容正文

生活经验

JavaScript arguments对象

發布時間:2023/11/27 生活经验 51 豆豆
生活随笔 收集整理的這篇文章主要介紹了 JavaScript arguments对象 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

1、在JavaScript中,arguments對象是比較特別的一個對象,實際上是當前函數的一個內置屬性。arguments非常類似Array,但實際上又不是一個Array實例。可以通過如下代碼得以證實(當然,實際上,在函數funcArg中,調用arguments是不必要寫成funcArg.arguments,直接寫arguments即可)。

1 Array.prototype.testArg = "test";
2 function funcArg() {
3     alert(funcArg.arguments.testArg);  
4     alert(funcArg.arguments[0]);
5 }
6 
7 alert(new Array().testArg); // result: "test"
8 funcArg(10);                // result: "undefined"  "10"

2、arguments對象的長度是由實參個數而不是形參個數決定的。形參是函數內部重新開辟內存空間存儲的變量,但是其與arguments對象內存空間并不重疊。對于arguments和值都存在的情況下,兩者值是同步的,但是針對其中一個無值的情況下,對于此無值的情形值不會得以同步。如下代碼可以得以驗證。

 1 function f(a, b, c){2     alert(arguments.length);   // result: "2"3     a = 100;4     alert(arguments[0]);       // result: "100"5     arguments[0] = "qqyumidi";6     alert(a);                  // result: "qqyumidi"7     alert(c);                  // result: "undefined"8     c = 2012;9     alert(arguments[2]);       // result: "undefined"
10 }
11 
12 f(1, 2);

3、由JavaScript中函數的聲明和調用特性,可以看出JavaScript中函數是不能重載的。

根據其他語言中重載的依據:"函數返回值不同或形參個數不同",我們可以得出上述結論:

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

第二:JavaScript中形參的個數嚴格意義上來講只是為了方便在函數中的變量操作,實際上實參已經存儲在arguments對象中了。

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

 1 function f(a){2     return a + 10;3 }4 5 function f(a){6     return a - 10;7 }8 9 // 在不考慮函數聲明與函數表達式區別的前提下,其等價于如下
10 
11 var f = function(a){
12     return a + 10;
13 }
14 
15 var f = function(a){
16     return a - 10;
17 }

4、arguments對象中有一個非常有用的屬性:callee。arguments.callee返回此arguments對象所在的當前函數引用。在使用函數遞歸調用時推薦使用arguments.callee代替函數名本身。

如下:

1 function count(a){
2     if(a==1){
3         return 1;
4     } 
5     return a + arguments.callee(--a);
6 }
7 
8 var mm = count(10);
9 alert(mm);
---------------------------------------------------------------------------------?

轉載自http://www.cnblogs.com/lwbqqyumidi/

轉載于:https://www.cnblogs.com/ztoz/p/5510293.html

總結

以上是生活随笔為你收集整理的JavaScript arguments对象的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。