首頁  >  文章  >  web前端  >  Javascript中的arguments對象

Javascript中的arguments對象

高洛峰
高洛峰原創
2017-01-04 17:04:041162瀏覽

在js中一切都是對象,連函數也是對象,函數名其實是引用函數定義對象的變數。

1、什麼是arguments?

這個函數體內的arguments非常特殊,實際上是所在函數的一個內建類別數組對象,可以用數組的[i]和.length。

2、有什麼作用?

js語法不支援重載!但可用arguments物件模擬重載效果。

arguments物件:函數物件內,自動建立的專門接收所有參數值得類別陣列物件。
arguments[i]: 取得傳入的下標為i的參數值
arguments.length: 取得傳入的參數個數!
  程式中可定義多個相同函數名,不同參數列表的函數,

  呼叫者不必區分每個函數的參數,

 『時,程式根據傳入的參數個數,自動傳入的參數個數,自動傳入的參數個數判斷選擇哪個函數執行。

例子如下:

// 1、如果用户传入一个参数,求平方
function sum(a){
console.log(a*a);
}
//如果用户传入两个参数,就求和
function sum(a,b){
console.log(a+b);
}
sum(4); //?
sum(4,5); //?

上述例子中本意是想讓同名函數sum()根據參數不同輸出不同結果,但是sum是函數名字,本質也是個變量,

第二個會覆蓋第一個,所以上述的正確輸出答案是:NaN,9.所以這樣顯然不可以。


如果用arguments,就簡單多了。


如下2個例子:

//2、
function calc(){
//如果用户传入一个参数,求平方
if(arguments.length==1){
console.log(arguments[0]*arguments[0]);
}else if(arguments.length==2){
//如果用户传入两个参数,就求和
console.log(arguments[0]+arguments[1]);
}
}
calc(4); //16
calc(4,5); //9 
/*3、无论用户传入几个数字,都可以求和*/
function add(){
//arguments:[]
//遍历arguments中每个元素,并累加
for(var i=0,sum=0;i<arguments.length;sum+=arguments[i++]);
return sum;//返回和
}
console.log(add(1,2,3)); //6
console.log(add(1,2,3,4,5,6)); //21

這就是JS利用arguments重載的效果,簡單理解就是一個函數重複利用.

arguments.length是有實參決定,也就是被呼叫時裡面的參數個數決定!


以上所述是小編給大家介紹的Javascript中的arguments對象的相關知識,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回覆大家的。在此也非常感謝大家對PHP中文網的支持!

更多Javascript中的arguments物件相關文章請關注PHP中文網!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn