1.js函數語法 2.js函數參數在內部是以一個數組的方式表示的。 3.js函數沒有重載。 ...
1.函數語法:
函數聲明的方式:
function 函數名(參數1,參數2…){
//函數體;
}
函數調用:函數名(參數1,參數2…);
函數內不一定都指定返回值。
如果需要指定返回值,可用 return 跟上要返回的值來指定返回值。
位於return語句後面的代碼在 return 語句所在的作用域下都不執行(如果 return 語句在一個函數體內,那麼這個 return 語句所在的作用域便是這個函數體內)。
如果return語句後面沒有跟返回值,那麼返回值為undefined。適用於不需要返回值的場景中。
2.函數的參數
js中函數的參數跟別的語言函數的參數不同。
假如你定義了一個函數,有三個參數,在的調用這個函數的時候,你可以不傳入參數,你也可以傳入2個3個4個參數,
原因在於js中的函數的參數在內部是以一個數組(這個數組可能包含0個或者多個值)的形式表示的。
你可以通過arguments這個對象來訪問函數的參數。arguments是一個數組對象。
如下麵例子:
// js中函數的參數 arguments function person(name,age,height){ console.log("姓名" + arguments[0] + "年齡" + arguments[1] + "身高" + arguments[2]); console.log(arguments.length); } person("lijinwen",10,"180cm"); 列印出如下值: // 姓名lijinwen年齡10身高180cm // 3
根據js函數的參數的這個特性,我們其實可以模仿函數的重載功能。即根據函數參數的個數不同,而得到不同的結果。但是這個並不是函數的重載。
// 模仿函數重載功能 function fun(){ if(arguments.length == 2){ console.log("兩個參數"); }else if(arguments.length == 3){ console.log("三個參數"); } } fun(1,2);//兩個參數 fun(1,2,3);//三個參數
3.函數沒有重載。如果兩個同名的函數,那麼後面的函數將覆蓋前面的函數。
// 函數沒有重載 function sum(a,b){ console.log("兩個參數"); } function sum(a,b,c){ console.log("三個參數"); } sum(1,2);//三個參數 sum(1,2,3);//三個參數
我們原本想如果往函數中傳入2個參數,則調用第一個函數列印出”兩個參數”,如果3個參數,調用第二個函數列印出”三個參數”。
看上面的代碼sum(1,2)有2個參數,結果列印出“三個參數”,那麼可以斷定它調用的是第二個函數。
由此證明,多個同名函數的情況下,最後一個函數將會覆蓋上面的同名函數。這種又稱作重載,因此 js 中函數沒有重載。