JavaScript 函式定義
JavaScript 使用關鍵字 function 定義函式。
函式可以通過宣告定義,也可以是一個表示式。
函式宣告
在之前的教程中,你已經瞭解了函式宣告的語法 :
function functionName(parameters) { 執行的程式碼 }
函式聲明後不會立即執行,會在我們需要的時候呼叫到。
例項
return a * b;
}
嘗試一下 ?
![]() |
分號是用來分隔可執行JavaScript語句。 由於函式宣告不是一個可執行語句,所以不以分號結束。 |
---|
函式表示式
JavaScript 函式可以通過一個表示式定義。
函式表示式可以儲存在變數中:
例項
嘗試一下 ?
在函式表示式儲存在變數後,變數也可作為一個函式使用:
例項
var z = x(4, 3);
嘗試一下 ?
以上函式實際上是一個 匿名函式 (函式沒有名稱)。
函式儲存在變數中,不需要函式名稱,通常通過變數名來呼叫。
![]() |
上述函式以分號結尾,因為它是一個執行語句。 |
---|
Function() 建構函式
在以上例項中,我們瞭解到函式通過關鍵字 function 定義。
函式同樣可以通過內建的 JavaScript 函式構造器(Function())定義。
例項
var x = myFunction(4, 3);
嘗試一下 ?
實際上,你不必使用建構函式。上面例項可以寫成:
例項
var x = myFunction(4, 3);
嘗試一下 ?
![]() |
在 JavaScript 中,很多時候,你需要避免使用 new 關鍵字。 |
---|
函式提升(Hoisting)
在之前的教程中我們已經瞭解了 "hoisting(提升)"。
提升(Hoisting)是 JavaScript 預設將當前作用域提升到前面去的的行為。
提升(Hoisting)應用在變數的宣告與函式的宣告。
因此,函式可以在宣告之前呼叫:
myFunction(5); function myFunction(y) { return y * y; }
使用表示式定義函式時無法提升。
自呼叫函式
函式表示式可以 "自呼叫"。
自呼叫表示式會自動呼叫。
如果表示式後面緊跟 () ,則會自動呼叫。
不能自呼叫宣告的函式。
通過新增括號,來說明它是一個函式表示式:
例項
var x = "Hello!!"; // 我將呼叫自己
})();
嘗試一下 ?
以上函式實際上是一個 匿名自我呼叫的函式 (沒有函式名)。
函式可作為一個值使用
JavaScript 函式作為一個值使用:
例項
return a * b;
}
var x = myFunction(4, 3);
嘗試一下 ?
JavaScript 函式可作為表示式使用:
例項
return a * b;
}
var x = myFunction(4, 3) * 2;
嘗試一下 ?
函式是物件
在 JavaScript 中使用 typeof 操作符判斷函式型別將返回 "function" 。
但是JavaScript 函式描述為一個物件更加準確。
JavaScript 函式有 屬性 和 方法。
arguments.length 屬性返回函式呼叫過程接收到的引數個數:
例項
return arguments.length;
}
嘗試一下 ?
toString() 方法將函式作為一個字串返回:
例項
return a * b;
}
var txt = myFunction.toString();
嘗試一下 ?
![]() |
函式定義作為物件的屬性,稱之為物件方法。 函式如果用於建立新的物件,稱之為物件的建構函式。 |
---|
箭頭函式
ES6 新增了箭頭函式。
箭頭函式表示式的語法比普通函式表示式更簡潔。
(引數1, 引數2, …, 引數N) => { 函式宣告 } (引數1, 引數2, …, 引數N) => 表示式(單一) // 相當於:(引數1, 引數2, …, 引數N) =>{ return 表示式; }
當只有一個引數時,圓括號是可選的:
(單一引數) => {函式宣告} 單一引數 => {函式宣告}
沒有引數的函式應該寫成一對圓括號:
() => {函式宣告}
例項
嘗試一下 ?
有的箭頭函式都沒有自己的 this。 不適合定義一個 物件的方法。
當我們使用箭頭函式的時候,箭頭函式會預設幫我們繫結外層 this 的值,所以在箭頭函式中 this 的值和外層的 this 是一樣的。
箭頭函式是不能提升的,所以需要在使用之前定義。
使用 const 比使用 var 更安全,因為函式表示式始終是一個常量。
如果函式部分只是一個語句,則可以省略 return 關鍵字和大括號 {},這樣做是一個比較好的習慣:
例項
嘗試一下 ?
注意:IE11 及更早 IE 版本不支援箭頭函式。