從JavaScript的函數(shù)重名看其初始化方式
回頭仔細(xì)一想,這個結(jié)果完全可以接受,因為腳本在頁面里本身就是順序執(zhí)行下來的,包括函數(shù)的定義,但然如果只是定義 function foo(){} 這種形式,我們是跟蹤不到函數(shù)初始化的??墒侨绻嵌x類的方式,我們就可以明顯地跟蹤到函數(shù)的初始化順序。比如:
function foo() {}
function foo.prototype.fn1() {}
function foo.prototype.fn2() {}我們就可以明顯地看到先執(zhí)行function foo.prototype.fn1(){}再執(zhí)行function foo.prototype.fn2(){}。
回到我們剛才說的JavaScript腳本函數(shù)重名問題上來,比如我們定義兩個函數(shù) funAlert():
function funAlert()
{
alert('A');
}
function funAlert()
{
alert('B');
}調(diào)用 funAlert(),那么將顯示一個MegBox,內(nèi)容為'B'。
為什么初始化函數(shù)會有這樣的效果?這里只用把上面兩個函數(shù)的定義改一下,就會一目了然了,我們把定義改為:
var fnAlert = new Function("alert('A')");
var fnAlert = new Function("alert('B')");
window.fnAlert();
var i = 0;
var i = 1;
if ( true )
{
t = 100;
}
alert(t);將顯示100,而
if ( true )
{
var t = 100;
}
alert(t);也是顯示100。
所以JavaScript的腳本函數(shù)名重不重復(fù)只是一個運(yùn)算的問題,和我們高級語言里的語法約束完全不是一回事,當(dāng)然也更不是overload的范疇。
腳本函數(shù)名重名有什么用呢?最直觀就是可以用來實現(xiàn)偽重載,比如我們不少免費的主頁空間常常會給你強(qiáng)加彈出窗口廣告,我們就可以在頁面第一行寫上:
var _open = window.open;
window.open = function() {}
</script>
相關(guān)文章
KnockoutJS 3.X API 第四章之表單value綁定
Knockout是一個以數(shù)據(jù)模型(data model)為基礎(chǔ)的能夠幫助你創(chuàng)建富文本,響應(yīng)顯示和編輯用戶界面的JavaScript類庫。這篇文章主要介紹了KnockoutJS 3.X API 第四章之表單value綁定的相關(guān)資料,需要的朋友可以參考下2016-10-10

