欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

javascript兩種function的定義介紹及區(qū)別說明

 更新時間:2013年05月02日 18:25:16   作者:  
javascript兩種function的定義方式function a(){}和a=function(){}具體使用如下,感興趣的朋友可以參考下,希望對你對你學習function的定義有所幫助
一般情況下兩者的調(diào)用結(jié)果是一樣的,但是還是有區(qū)別的。
第一種方式:
復制代碼 代碼如下:

function a(){
alert('old');
}
var b=a;
function a(){
b();
alert('new');
}
a();//瀏覽器就會出現(xiàn)內(nèi)存溢出的情況

第二種方式:
復制代碼 代碼如下:

function a(){
alert('old');
}
var b=a;
var a=function(){
b();
alert('new');
}
a();//瀏覽器就會按順序alert出‘old'和‘new'

這里就可以很明顯區(qū)分兩個方式的區(qū)別了。定義的順序不同。
第一種,剛開始其實沒有重新定義 a 這個function 而在里面執(zhí)行了其本身。
第二種方式, a = function () 這里沒有執(zhí)行到 function 里面的代碼 a 已經(jīng)被重新定義了。所以這里的重定義是有效的
補充1:
復制代碼 代碼如下:

function a(){
alert('old');
}
var b=a;
function a(){
b();
alert('new');
}

編譯時: 首先a被定義為alert("old"), 接著又被定義成b();alert("new");
運行時: b = function a(){b();alert("new");}, 此時b和a一樣, 函數(shù)體中直接調(diào)用b, 無論從a調(diào)用還是從b調(diào)用結(jié)果都一樣, 產(chǎn)生堆棧溢出
另一方面
復制代碼 代碼如下:

function a(){
alert('old');
}
var b=a;
var a=function(){
b();
alert('new');
}

編譯時: a被定義為alert("old")
運行時: b=function a(){alert("old")}; a=function(){b();alert("new")}; 此時b的函數(shù)體中不包括ab中任何一個, a只調(diào)用b... 無論怎樣都不會產(chǎn)生堆棧溢出...
補充2:
一般來說,都會用第一種的寫法來避免代碼污染,但如果你需要保留原function,就要用第二種寫法,反正兩種方法都是符合w3c的。
事實上第一種寫法是后來才有的,這種寫法是經(jīng)過優(yōu)化的。

相關(guān)文章

最新評論