1、arguments是JavaScript裏的一個內置對象,它很古怪,也經常被人所忽略,但實際上很重要.所有主要的js函數庫都利用了arguments對象.
所有的函數都有屬於自己的一個arguments對象,它包括了函所要調用的參數。他不是一個數組,如果用typeof arguments,返回的是’object’。雖然我們可以用調用數據的方法來調用arguments。比如length,還有index方法。但是數 組的push和pop對象是不適用的。
2、把arguments對象轉換成一個真正的數組
雖然arguments對象不是一個真正的javascript數組,但是我們還是可以輕易的把它轉換成標準的數據 ,然後進行數組操作。
var args = Array.prototype.slice.call(arguments);
JavaScript arguments對象
3、在JavaScript中,arguments對象是比較特別的一個對象,實際上是當前函數的一個內置屬性。arguments非常類似Array,但實際上又不是一個Array實例。可以通過如下代碼得以證實(當然,實際上,在函數funcArg中,調用arguments是不必要寫成funcArg.arguments,直接寫arguments即可)。
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"
4、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);
5、由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 }
6、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);