JavaScript 函式定義

JavaScript 使用關鍵字 function 定義函式。

函式可以通過宣告定義,也可以是一個表示式。


函式宣告

在之前的教程中,你已經瞭解了函式宣告的語法 :

function functionName(parameters) {
  執行的程式碼
}

函式聲明後不會立即執行,會在我們需要的時候呼叫到。

例項

function myFunction(a, b) {
return a * b;
}

嘗試一下 ?

Note 分號是用來分隔可執行JavaScript語句。
由於函式宣告不是一個可執行語句,所以不以分號結束。


函式表示式

JavaScript 函式可以通過一個表示式定義。

函式表示式可以儲存在變數中:

例項

var x = function (a, b) {return a * b};

嘗試一下 ?

在函式表示式儲存在變數後,變數也可作為一個函式使用:

例項

var x = function (a, b) {return a * b};
var z = x(4, 3);

嘗試一下 ?

以上函式實際上是一個 匿名函式 (函式沒有名稱)。

函式儲存在變數中,不需要函式名稱,通常通過變數名來呼叫。

Note 上述函式以分號結尾,因為它是一個執行語句。


Function() 建構函式

在以上例項中,我們瞭解到函式通過關鍵字 function 定義。

函式同樣可以通過內建的 JavaScript 函式構造器(Function())定義。

例項

var myFunction = new Function("a", "b", "return a * b");

var x = myFunction(4, 3);

嘗試一下 ?

實際上,你不必使用建構函式。上面例項可以寫成:

例項

var myFunction = function (a, b) {return a * b};

var x = myFunction(4, 3);

嘗試一下 ?

Note 在 JavaScript 中,很多時候,你需要避免使用 new 關鍵字。


函式提升(Hoisting)

在之前的教程中我們已經瞭解了 "hoisting(提升)"。

提升(Hoisting)是 JavaScript 預設將當前作用域提升到前面去的的行為。

提升(Hoisting)應用在變數的宣告與函式的宣告。

因此,函式可以在宣告之前呼叫:

myFunction(5);

function myFunction(y) {
    return y * y;
}

使用表示式定義函式時無法提升。


自呼叫函式

函式表示式可以 "自呼叫"。

自呼叫表示式會自動呼叫。

如果表示式後面緊跟 () ,則會自動呼叫。

不能自呼叫宣告的函式。

通過新增括號,來說明它是一個函式表示式:

例項

(function () {
var x = "Hello!!"; // 我將呼叫自己
})();

嘗試一下 ?

以上函式實際上是一個 匿名自我呼叫的函式 (沒有函式名)。


函式可作為一個值使用

JavaScript 函式作為一個值使用:

例項

function myFunction(a, b) {
return a * b;
}

var x = myFunction(4, 3);

嘗試一下 ?

JavaScript 函式可作為表示式使用:

例項

function myFunction(a, b) {
return a * b;
}

var x = myFunction(4, 3) * 2;

嘗試一下 ?


函式是物件

在 JavaScript 中使用 typeof 操作符判斷函式型別將返回 "function" 。

但是JavaScript 函式描述為一個物件更加準確。

JavaScript 函式有 屬性 方法

arguments.length 屬性返回函式呼叫過程接收到的引數個數:

例項

function myFunction(a, b) {
return arguments.length;
}

嘗試一下 ?

toString() 方法將函式作為一個字串返回:

例項

function myFunction(a, b) {
return a * b;
}

var txt = myFunction.toString();

嘗試一下 ?

Note 函式定義作為物件的屬性,稱之為物件方法。
函式如果用於建立新的物件,稱之為物件的建構函式。

箭頭函式

ES6 新增了箭頭函式。

箭頭函式表示式的語法比普通函式表示式更簡潔。

(引數1, 引數2, …, 引數N) => { 函式宣告 }

(引數1, 引數2, …, 引數N) => 表示式(單一)
// 相當於:(引數1, 引數2, …, 引數N) =>{ return 表示式; }

當只有一個引數時,圓括號是可選的:

(單一引數) => {函式宣告}
單一引數 => {函式宣告}

沒有引數的函式應該寫成一對圓括號:

() => {函式宣告}

例項

// ES5 var x = function(x, y) { return x * y; } // ES6 const x = (x, y) => x * y;

嘗試一下 ?

有的箭頭函式都沒有自己的 this。 不適合定義一個 物件的方法

當我們使用箭頭函式的時候,箭頭函式會預設幫我們繫結外層 this 的值,所以在箭頭函式中 this 的值和外層的 this 是一樣的。

箭頭函式是不能提升的,所以需要在使用之前定義。

使用 const 比使用 var 更安全,因為函式表示式始終是一個常量。

如果函式部分只是一個語句,則可以省略 return 關鍵字和大括號 {},這樣做是一個比較好的習慣:

例項

const x = (x, y) => { return x * y };

嘗試一下 ?

注意:IE11 及更早 IE 版本不支援箭頭函式。