目前為止,我們一直沒有對函數宣告和函數表達式加以區別。而實際上,解析器在向執行環境中載入資料時,對函數宣告和函數表達式並非一視同仁。解析器會率先讀取函數聲明,並使其在執行任何程式碼之前可用(可以存取);至於函數表達式,則必須等到解析器執行到它所在的程式碼行,才會真正被解釋執行。如下例:
程式碼如下:
alert(sum(10,10)); function sum(num1,num2) { return num1+num2; }
以上程式碼完全可以正確執行,因為在程式碼開始執行之前,解析器就已經透過一個名為函數宣告提升(function declaration hoisting)的過程,讀取並將函數宣告新增至執行環境。將程式碼求值時,JavaScript引擎在第一遍會宣告函數並將它們放到原始碼樹的頂部。所以,即使宣告函數的程式碼在呼叫它的程式碼後面,JavaScript引擎也能把函數宣告提升到頂部。如果像下面的例子所示,把上面的函數宣告改為等價的函數表達式,就會在執行的時候出現錯誤。
程式碼如下:
alert(sum(10,10)); var sum=function(num1,num2) { return num1+num2; };
除了宣告時候可以透過變數存取函數這一點區別之外,文法函數宣告與函數表達式的語法函數其實是等價的。
註:也可以同時呼叫函數宣告和函數表達式,例如 var sum=function sum(){}。不過,這種語法在Safari中會導致錯誤。
以上所述就是本文的全部內容了,希望對大家學習javascript能夠有所幫助。
更多相關教學請造訪 javascript教學