ECMAScript中函數沒有標簽名的特性,所以ECMAScript函數中沒有重載。
Javascript中arguments的存在可以彌補javascript中函數沒有重載的不足。
Javascript中函數中的參數是以數組的形式保存的,所以在JavaScript中調用函數給函數傳遞的參數時,不會受到我們定義函數時設置的參數個數的限制。也就是說如果我們給一個函數定義了2個參數,我們傳遞的時候可以不傳,可以傳一個,也可以傳兩個,傳三個...都可以,不會受函數參數個數的影響。arguments類似一個數組(但是不是真正的Array對象),同樣可以像數組一樣用方括號來訪問它的每一個值,並用arguments.length來判斷參數的個數。
應該說我們可以向ECMAScript(javascript是對ECMAScript標准的實現)函數任意的傳遞參數,並可以通過arguments對象來訪問這些參數。
arguments的使用:
function myfun() { console.log(arguments.length); } myfun("1","2");//2 myfun("1");//1 myfun();//0
function myfun(num1,num2) { if(arguments.length === 1){ console.log(arguments[0]); } else if(arguments.length === 2) { console.log(arguments[0]+arguments[1]); } else if(arguments.length === 3) { console.log(num1+num2+arguments[2]); }else { console.log(arguments[0]+" "+num1); } } myfun(1);//1 myfun(1,2);//3 myfun(1,2,3);//6 myfun();//undefined undefined
命名參數可以和arguments一起使用
和其他oo語言不一樣,在ECMAScript中,所有參數傳遞的都是值,不可能通過引用傳遞參數(畢竟arguments中保存的都是參數的值)。
arguments對象中還定義了callee屬性,用來引用當前正在執行的函數,例如在遞歸中使用:
function factorial(num) { if(num <=1 ) { return 1; } else { return num*arguments.callee(num-1); } } console.log(factorial(5));//120
需要注意的是如果一個函數的參數有3個,傳遞的實參只有2個,那么arguments[2]和第三個參數是不共享的.
function foo(x, y, z) { // 聲明的函數參數數量arguments (x, y, z) console.log(foo.length); // 3 // 真正傳進來的參數個數(only x, y) console.log(arguments.length); // 2 // 參數的callee是函數自身 console.log(arguments.callee === foo); // true // 參數共享 console.log(x === arguments[0]); // true console.log(x); // 10 arguments[0] = 20; console.log(x); // 20 x = 30; console.log(arguments[0]); // 30 // 不過,沒有傳進來的參數z,和參數的第3個索引值是不共享的 z = 40; console.log(arguments[2]); // undefined arguments[2] = 50; console.log(z); // 40 } foo(10, 20);