js中函數(shù)聲明與函數(shù)表達式
目前為止,我們一直沒有對函數(shù)聲明和函數(shù)表達式加以區(qū)別。而實際上,解析器在向執(zhí)行環(huán)境中加載數(shù)據(jù)時,對函數(shù)聲明和函數(shù)表達式并非一視同仁。解析器會率先讀取函數(shù)聲明,并使其在執(zhí)行任何代碼之前可用(可以訪問);至于函數(shù)表達式,則必須等到解析器執(zhí)行到它所在的代碼行,才會真正被解釋執(zhí)行。如下例子:
alert(sum(10,10));
function sum(num1,num2)
{
return num1+num2;
}
以上代碼完全可以正確執(zhí)行,因為在代碼開始執(zhí)行之前,解析器就已經(jīng)通過一個名為函數(shù)聲明提升(function declaration hoisting)的過程,讀取并將函數(shù)聲明添加到執(zhí)行環(huán)境中。對代碼求值時,JavaScript引擎在第一遍會聲明函數(shù)并將它們放到源代碼樹的頂部。所以,即使聲明函數(shù)的代碼在調(diào)用它的代碼后面,JavaScript引擎也能把函數(shù)聲明提升到頂部。如果像下面的例子所示,把上面的函數(shù)聲明改為等價的函數(shù)表達式,就會在執(zhí)行的時候出現(xiàn)錯誤。
alert(sum(10,10));
var sum=function(num1,num2)
{
return num1+num2;
};
以上代碼會在運行的時候出現(xiàn)錯誤,原因在于函數(shù)位于一個初始化語句中,而不是一個函數(shù)聲明。換句話講,在執(zhí)行到函數(shù)所在的語句之前,變量sum中不會保存有對函數(shù)的引用;而且,由于第一行代碼就會導(dǎo)致“unexpected identifier”(意外標識符)錯誤,實際上也不會執(zhí)行到下一行。
除了聲明時候可以通過變量訪問函數(shù)這一點區(qū)別之外,函數(shù)聲明與函數(shù)表達式的語法其實是等價的。
注:也可以同時調(diào)用函數(shù)聲明和函數(shù)表達式,例如 var sum=function sum(){}。不過,這種語法在Safari中會導(dǎo)致錯誤。
以上所述就是本文的全部內(nèi)容了,希望對大家學(xué)習(xí)javascript能夠有所幫助。
相關(guān)文章
分享一道筆試題[有n個直線最多可以把一個平面分成多少個部分]
今天地鐵上和一個同事閑聊,給我說的一道題,回來想了想,寫出來的,說來慚愧,我用的是行測方面數(shù)字推理里面的知識歸納出來的,當然這個可以用遞歸寫出來,說說我的代碼,以及遞歸的思路2012-10-10javascript自定義in_array()函數(shù)實現(xiàn)方法
這篇文章主要介紹了javascript自定義in_array()函數(shù)實現(xiàn)方法,涉及javascript數(shù)組的遍歷與查找相關(guān)技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-08-08JS實現(xiàn)iframe自適應(yīng)高度的方法(兼容IE與FireFox)
這篇文章主要介紹了JS實現(xiàn)iframe自適應(yīng)高度的方法,涉及javascript與iframe交互動態(tài)操作頁面元素屬性的相關(guān)技巧,需要的朋友可以參考下2016-06-06javascript AOP 實現(xiàn)ajax回調(diào)函數(shù)使用比較方便
javascript AOP 實現(xiàn)ajax回調(diào)函數(shù)使用比較方便,需要的朋友可以參考下。2010-11-11