在一些類似c語言的程式設計語言中,花括弧內的每一段代碼都具有各自的範圍,而且變數在聲明他們的程式碼片段之外是不可見的,我們稱為塊級範圍(block scope),而javascript中沒有塊級範圍。取而代之的javascript使用的是函數範圍(function scope):變數在聲明它的函數體以及這個函數體嵌套的任意函數體內都是有定義的。 在如下代碼中,在不同位置定義的i,j和k,他們再同一個範圍內都是有定義的
複製代碼 代碼如下:
function text(o)
{
var i=0;
alert(typeof o);
if(typeof o == "string")
{
var j=0;
for(var k=0;k<10;k++)
{
alert(k);//輸出0-9
}
alert(k);//輸出10
}
alert(j);//輸出0
}
javascript的函數範圍指在函數內部聲明的所有的變數在函數體內始終是可見的。有意思的是,這意味著變數在聲明之前甚至已經可用。javascript的這個特性被非正式的稱為聲明提前(hoisting),即javascript的函數體內聲明的所有的變數(不涉及賦值)都被“提前”至函數體的頂部。看以下代碼
複製代碼 代碼如下:
var global="globas";
function globals()
{
alert(global);//undefined
var global="hello QDao";
alert(global);//hello QDao
}
由於函數範圍的特性,局部變數在整個函數體始終是有定義的,也就是說在函數體內部變數遮蓋了同名的全域變數。儘管如此在程式執行到var語句的時候,局部變數才會被真正的賦值,因此,上述過程等價於:將函數內的變數聲明“提前”至函數體頂部,同事變數初始化留在原來的位置:
複製代碼 代碼如下:
var global="globas";
function globals()
{
var global;
alert(global);//undefined
global="hello QDao";
alert(global);//hello QDao
}