函數的參數 參數是指由外部傳入到函數中的變數,僅作為變數使用,但是該變數可以是任何內容,包括函數。被傳入的參數作為私有變數使用,可以被覆蓋掉。 參數排列是嚴格按照參數的順序填入的 。 JavaScript中函數的參數分為 形參 和 實參 。 形參 :是在定義函數時使用的參數,目的是用來接收調用該函數 ...
函數的參數
參數是指由外部傳入到函數中的變數,僅作為變數使用,但是該變數可以是任何內容,包括函數。被傳入的參數作為私有變數使用,可以被覆蓋掉。參數排列是嚴格按照參數的順序填入的。
JavaScript中函數的參數分為形參和實參。
形參:是在定義函數時使用的參數,目的是用來接收調用該函數時傳進來的實際參數。
實參:是在調用時傳遞給函數的參數。
function myfun(a,b){ //形參就是a和b
return a+b;
}
console.log(myfun(1,2));//輸出5 //實參就是1和2
函數的形參沒有限制,可以沒有或者多個。形參的數量可以通過函數的length屬性獲取。
function myfun(a,b,c){
return a+b+c;
}
console.log(myfun.length); //返回3,形參的個數
一般來說,函數的形參和實參個數是相等的,但在JavaScript中沒有規定兩者必須相等。
函數中實參與形參是依次對應的,嚴格按照填入的順序,即第1個實參的值傳遞給第1個形參,第2個實參的值傳遞給第2個形參,以此類推
如果實參個數大於形參,那麼多出的實參就無法被形參訪問,不傳遞其值而被忽略掉。
如果形參個數大於實參,那麼多出的形參值為undefined。
var myfun=function(m,n){ // 2個形參
document.write("m="+m);
document.write("n="+n);
}
myfun(1,2); // 2個實參,實參等於形參
document.write("<br />");
myfun(1,2,3); // 3個實參,實參大於形參
ocument.write("<br />");
myfun(1); // 1個實參,實參小於形參
輸出結果為:
m=1 n=2
m=1 n=2
m=1 n=undefined
函數也能作為參數傳遞給另一個函數,也可以作為返回值。有利於進行模塊化編程。如下所示
function a(f,x,y){ //定義一個函數a,裡面的形參f就是函數
return f(x,y); //函數a返回的就是函數f的執行結果
}
function b(x,y){
return x+y;
}
console.log(a(b,1,2));//輸出3,這裡的b就是函數b,也就是形參f
如果出現參數的個數不確定 我們可以不定義參數
如果是單純的值傳遞: 形參的賦值,不會影響到實參。但是,如果是引用傳遞,那麼變形參的值,相當於改變了引用,會改變實參的值
拓展:JavaScript定義了arguments對象,用於在函數內部執行,arguments.length是可以快速獲取函數的實參個數,使用arguments[n]可以獲取實參的值。