function funName([args]) { statements }funName 是函數名,與變數名一樣必須是 JavaScript 合法的識別符號。在函數名之後是一個由一個小括號包含的參數列,引數之間以逗號分隔。引數是可選的,沒有數量限制。
function funName() {} //空函數
如果使用匿名函數,則可以省略函數名。function () {} //匿名空函數
var funName = new Function(p1, p2, ..., pn, body);Function() 的引數型別都是字串,p1~pn 表示所建立函數的引數名稱列表,body 表示所建立函數的函數結構體語句,在 body 語句之間以分號分隔。
var f = new Function ("a", "b", "return a+b"); //通過建構函式來克隆函數結構在上面程式碼中,f 就是所建立函數的名稱。同樣是定義函數,使用 function 語句可以設計相同結構的函數。
function f(a, b) { //使用function語句定義函數結構 return a + b; }
var f = new Function(); //定義空函數
var f = new Function("a", "b", "c", "return a+b+c"); var f = new Function("a, b, c", "return a+b+c"); var f = new Function("a,b", "c", "return a+b+c");使用 Function() 建構函式不是很常用,因為一個函數體通常會包括很多程式碼,如果將這些程式碼以一行字串的形式進行傳遞,程式碼的可讀性會很差。
function ([args]) { statements }
function (a, b) { //函數直接量 return a + b; }在上面程式碼中,函數直接量與使用 function 語句定義函數結構基本相同,它們的結構都是固定的。但是函數直接量沒有指定函數名,而是直接利用關鍵字 function 來表示函數的結構,這種函數也被稱為匿名函數。
//把函數作為一個值直接賦值給變數 f var f = function (a, b) { return a + b; };當把函數結構作為一個值賦值給變數之後,變數就可以作為函數被呼叫,此時變數就指向那個匿名函數。
console.log(f(1,2)); //返回值3
console.log( //把函數作為一個運算元進行呼叫 (function (a,b) { return a + b; })(1, 2)); //返回數值3
function f(x,y) { //外層函數 function e(a, b) { //內層函數 return a * b; } return x + y; }
function f(x,y) { function e(a,b) { return a * b; } return e(3,6) + y; //內層函數參與表示式運算有效 console.log(e(3,6)); //無效的呼叫 } console.log(f(3,6)); //呼叫外層函數