JS兩種定義方式的區(qū)別、內(nèi)部原理
更新時間:2013年11月21日 15:07:05 投稿:whsnow
方式1 是典型的函數(shù)聲明(Function declarations)。方式2 是函數(shù)表達(dá)式(Function expressions),未必所有人都知道其區(qū)別,內(nèi)部原理
相信兩種方式大家都用過,但未必所有人都知道其 區(qū)別,內(nèi)部原理。
復(fù)制代碼 代碼如下:
// 方式1
function func1(x,y){
// your code
}
// 方式2
var func2 = function(x,y){
// your code
}
方式1 是典型的函數(shù)聲明(Function declarations)。
方式2 是函數(shù)表達(dá)式(Function expressions),將一個匿名函數(shù)賦值給一個變量?;蛘哒f方式2中創(chuàng)建了一個具有形參為x,y的匿名函數(shù),然后把該匿名函數(shù)賦值給變量func2。
其主要區(qū)別在于:
1, 函數(shù)聲明需顯示的指定函數(shù)名,這里是func1;函數(shù)表達(dá)式則使用匿名函數(shù)
2, 方式1在代碼執(zhí)行之前(解釋期)被加載到作用域中,方式2則需在代碼執(zhí)行時(運行期)加載
一個簡單示例就明白了它們在使用上的區(qū)別
復(fù)制代碼 代碼如下:
alert(func1); // --> func1源碼
alert(func2); // --> undefined
// 方式1
function func1(x,y){
// your code
}
// 方式2
var func2 = function(x,y){
// your code
}
可以看到,第一次彈出的是func1的源碼,第二次卻是undefined。即采用方式1(函數(shù)聲明)定義函數(shù),可以在該函數(shù)代碼之上使用它,采用方式2(函數(shù)表達(dá)式)定義函數(shù)則不能在其定義前使用,只能在其定義后使用。
其內(nèi)部涉及到 執(zhí)行上下文(Execution context)及 激活對象(Activation object)。想更深了解的請閱讀EcmaScript 5文檔。
最近發(fā)現(xiàn)越來越多的人喜歡使用方式2定義函數(shù),尤其在嵌套函數(shù)中。如單純的定義一個函數(shù)個人還是習(xí)慣方式1。
相關(guān)文章
詳解Node.js模塊間共享數(shù)據(jù)庫連接的方法
我們可以寫一個統(tǒng)一的數(shù)據(jù)庫連接模塊來供本地Node環(huán)境下各模塊間共享使用,接下來就來詳解Node.js模塊間共享數(shù)據(jù)庫連接的方法2016-05-05JavaScript使用escape()、encodeURI()和decodeURI()實現(xiàn)URI編碼解碼
這篇文章介紹了JavaScript使用escape()、encodeURI()和decodeURI()實現(xiàn)URI編碼解碼的方法,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-05-05深入理解JavaScript中的語法和代碼結(jié)構(gòu)
這篇文章主要介紹了JavaScript中的語法和代碼結(jié)構(gòu),對JS初學(xué)者而言,這些基礎(chǔ)一定要看一下2021-05-05JS中for循序中延遲加載動態(tài)效果的具體實現(xiàn)
今天在做一個前端的效果的時候碰到一個棘手的問題,就是實現(xiàn)一個動態(tài)的圓柱效果,廢話不多少,直接上代碼2013-08-08傳智播客學(xué)習(xí)之JavaScript基礎(chǔ)篇
前幾天學(xué)習(xí)了JavaScript,但是一直由于忙碌的原因,沒有來得及進(jìn)行總結(jié),今天終于有時間進(jìn)行一個全面總結(jié)了,希望給正在努力學(xué)習(xí)的朋友們一點小小幫助。2009-11-11