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

Javascript學(xué)習(xí)筆記2 函數(shù)

 更新時間:2010年01月11日 00:14:18   作者:  
在Javascript中,function才是Javascript的第一型。當我們寫下一段函數(shù)時,其實不過是建立了一個function類型的實體。
就像我們可以寫成這樣的形式一樣:
復(fù)制代碼 代碼如下:

function Hello() {
alert("Hello");
}
Hello();
var Hello = function () {
alert("Hello");
}
Hello();

其實都是一樣的。
但是當我們對其中的函數(shù)進行修改時,會發(fā)現(xiàn)很奇怪的問題。
復(fù)制代碼 代碼如下:

<script type="text/javascript">
function Hello() {
alert("Hello");
}
Hello();
function Hello() {
alert("Hello World");
}
Hello();
</script>

我們會看到這樣的結(jié)果:連續(xù)輸出了兩次Hello World。而非我們想象中的Hello和Hello World。
這是因為Javascript并非完全的按順序解釋執(zhí)行,而是在解釋之前會對Javascript進行一次“預(yù)編譯”,在預(yù)編譯的過程中,會把定義式的函數(shù)優(yōu)先執(zhí)行,也會把所有var變量創(chuàng)建,默認值為undefined,以提高程序的執(zhí)行效率。也就是說上面的一段代碼其實被JS引擎預(yù)編譯為這樣的形式:
復(fù)制代碼 代碼如下:

<script type="text/javascript">
var Hello = function() {
alert("Hello");
}
Hello = function() {
alert("Hello World");
}
Hello();
Hello();
</script>

我們可以通過上面的代碼很清晰地看到,其實函數(shù)也是數(shù)據(jù),也是變量,我們也可以對“函數(shù)“進行賦值(重賦值)。當然,我們?yōu)榱朔乐惯@樣的情況,也可以這樣:
復(fù)制代碼 代碼如下:

<script type="text/javascript">
function Hello() {
alert("Hello");
}
Hello();
</script>
<script type="text/javascript">
function Hello() {
alert("Hello World");
}
Hello();
</script>

這樣,程序被分成了兩段,JS引擎也就不會把他們放到一起了。

相關(guān)文章

最新評論