JAVASCRIPT函數(shù)作用域和提前聲明 分享
更新時(shí)間:2013年08月22日 15:04:44 作者:
這篇文章介紹了JAVASCRIPT函數(shù)作用域和提前聲明,有需要的朋友可以參考一下
一些語(yǔ)言如C、java都有塊級(jí)作用域,即花括號(hào)內(nèi)的每一段代碼都具有各自的作用域,而且變量在聲明它們的代碼段之外是不可見(jiàn)的,但是javascript沒(méi)有塊級(jí)作用域。javascript使用函數(shù)作用域,即變量在聲明它們的函數(shù)體以及這個(gè)函數(shù)體嵌套的任意函數(shù)體內(nèi)都是有定義的,也即函數(shù)內(nèi)聲明的所有變量在函數(shù)體內(nèi)始終是可見(jiàn)的。這樣就意味著變量在聲明之前就可以使用,這個(gè)特性被稱為"聲明提前",即javascript函數(shù)里聲明的所有變量都被提前至函數(shù)的頂部。來(lái)看個(gè)例子。
var test1 = "globalVariable";
function test(){
console.log(test1);
var test1 = "localVariable";
console.log(test1);
}
上述函數(shù)執(zhí)行的結(jié)果是:先輸出"undefined",再輸出"localVariable"。
很多人都會(huì)誤以為結(jié)果是:先輸出"globalVariable,再輸出localVariable"。其實(shí)不然,由于函數(shù)作用域的特性,局部變量在整個(gè)函數(shù)體始終是有定義的,也即,在函數(shù)體內(nèi)局部變量遮蓋了同名全局變量,但是只有在程序執(zhí)行到var語(yǔ)句的時(shí)候,局部變量才會(huì)被真正的賦值。因此,上述過(guò)程相當(dāng)于,將函數(shù)內(nèi)的變量聲明提前至函數(shù)體頂部,同時(shí)變量初始化留在原來(lái)的位置。就相當(dāng)于如下這個(gè)函數(shù)
var test1 = "globalVariable";
function test(){
var test1; //將函數(shù)內(nèi)的變量聲明提前至函數(shù)頂部
console.log(test1);
test1 = "localVariable"; //賦值
console.log(test1);
}
但是,如果函數(shù)內(nèi)沒(méi)有用var聲明變量,情況又有所不同。
var test1 = "globalVariable";
function test(){
console.log(test1);
test1 = "localVariable";
console.log(test1);
}
這個(gè)函數(shù)執(zhí)行的結(jié)果是:先輸出"globalVariable",再輸出"localVariable"。
由于函數(shù)體內(nèi)的test1變量沒(méi)有用var聲明,就默認(rèn)為全局變量,當(dāng)然就不存在變量提前聲明的問(wèn)題。第一行就會(huì)輸出"globalVariable",而第三行改變了test1全局變量的值,輸出了"localVariable"。
復(fù)制代碼 代碼如下:
var test1 = "globalVariable";
function test(){
console.log(test1);
var test1 = "localVariable";
console.log(test1);
}
上述函數(shù)執(zhí)行的結(jié)果是:先輸出"undefined",再輸出"localVariable"。
很多人都會(huì)誤以為結(jié)果是:先輸出"globalVariable,再輸出localVariable"。其實(shí)不然,由于函數(shù)作用域的特性,局部變量在整個(gè)函數(shù)體始終是有定義的,也即,在函數(shù)體內(nèi)局部變量遮蓋了同名全局變量,但是只有在程序執(zhí)行到var語(yǔ)句的時(shí)候,局部變量才會(huì)被真正的賦值。因此,上述過(guò)程相當(dāng)于,將函數(shù)內(nèi)的變量聲明提前至函數(shù)體頂部,同時(shí)變量初始化留在原來(lái)的位置。就相當(dāng)于如下這個(gè)函數(shù)
復(fù)制代碼 代碼如下:
var test1 = "globalVariable";
function test(){
var test1; //將函數(shù)內(nèi)的變量聲明提前至函數(shù)頂部
console.log(test1);
test1 = "localVariable"; //賦值
console.log(test1);
}
但是,如果函數(shù)內(nèi)沒(méi)有用var聲明變量,情況又有所不同。
復(fù)制代碼 代碼如下:
var test1 = "globalVariable";
function test(){
console.log(test1);
test1 = "localVariable";
console.log(test1);
}
這個(gè)函數(shù)執(zhí)行的結(jié)果是:先輸出"globalVariable",再輸出"localVariable"。
由于函數(shù)體內(nèi)的test1變量沒(méi)有用var聲明,就默認(rèn)為全局變量,當(dāng)然就不存在變量提前聲明的問(wèn)題。第一行就會(huì)輸出"globalVariable",而第三行改變了test1全局變量的值,輸出了"localVariable"。
相關(guān)文章
javaScript 事件綁定、事件冒泡、事件捕獲和事件執(zhí)行順序整理總結(jié)
這篇文章主要介紹了javaScript 事件綁定、事件冒泡、事件捕獲和事件執(zhí)行順序整理總結(jié)的相關(guān)資料,需要的朋友可以參考下2016-10-10JavaScript中splice與slice的區(qū)別
本文給大家分享的是JavaScript中的splice和slice的用法和區(qū)別,slice()方法和splice()方法都是原生js中對(duì)數(shù)組操作的方法,下面我們來(lái)詳細(xì)探討下2017-05-05JavaScript DOM 學(xué)習(xí)第三章 內(nèi)容表格
在這一章我會(huì)解釋我的網(wǎng)站上的所有頁(yè)面都在運(yùn)行的內(nèi)容表格的代碼。他會(huì)生產(chǎn)這個(gè)頁(yè)面的所有h3和h4的列表,然后給他們添加一個(gè)鏈接。2010-02-02一個(gè)JavaScript變量聲明的知識(shí)點(diǎn)
JavaScript變量聲明很簡(jiǎn)單,但是這里也有要學(xué)習(xí)的知識(shí)點(diǎn),對(duì)于JavaScript基礎(chǔ)學(xué)習(xí)很重要。2013-10-10Javascript開(kāi)發(fā)之三數(shù)組對(duì)象實(shí)例介紹
Javascript開(kāi)發(fā)之三組數(shù)對(duì)象詳細(xì)介紹,需要的朋友可以參考下2012-11-11