javascript函數(shù)作用域?qū)W習(xí)示例(js作用域)
在一些類似c語言的編程語言中,花括號(hào)內(nèi)的每一段代碼都具有各自的作用域,而且變量在聲明他們的代碼段之外是不可見的,我們稱為塊級(jí)作用域(block scope),而javascript中沒有塊級(jí)作用域。取而代之的javascript使用的是函數(shù)作用域(function scope):變量在聲明它的函數(shù)體以及這個(gè)函數(shù)體嵌套的任意函數(shù)體內(nèi)都是有定義的。 在如下代碼中,在不同位置定義的i,j和k,他們?cè)偻粋€(gè)作用域內(nèi)都是有定義的
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的函數(shù)作用域指在函數(shù)內(nèi)部聲明的所有的變量在函數(shù)體內(nèi)始終是可見的。有意思的是,這意味著變量在聲明之前甚至已經(jīng)可用。javascript的這個(gè)特性被非正式的稱為聲明提前(hoisting),即javascript的函數(shù)體內(nèi)聲明的所有的變量(不涉及賦值)都被“提前”至函數(shù)體的頂部。看以下代碼
var global="globas";
function globals()
{
alert(global);//undefined
var global="hello QDao";
alert(global);//hello QDao
}
由于函數(shù)作用域的特性,局部變量在整個(gè)函數(shù)體始終是有定義的,也就是說在函數(shù)體內(nèi)部變量遮蓋了同名的全局變量。盡管如此在程序執(zhí)行到var語句的時(shí)候,局部變量才會(huì)被真正的賦值,因此,上述過程等價(jià)于:將函數(shù)內(nèi)的變量聲明“提前”至函數(shù)體頂部,同事變量初始化留在原來的位置:
var global="globas";
function globals()
{
var global;
alert(global);//undefined
global="hello QDao";
alert(global);//hello QDao
}
相關(guān)文章
javascript函數(shù)作用域?qū)W習(xí)示例(js作用域)
javascript中沒有塊級(jí)作用域,取而代之的javascript使用的是函數(shù)作用域,下面使用示例學(xué)習(xí)一下js作用域的使用方法2014-01-01JavaScript fontsize方法入門實(shí)例(按照指定的尺寸來顯示字符串)
這篇文章主要介紹了JavaScript fontsize方法入門實(shí)例,fontsize方法用于按照指定的尺寸來顯示字符串,需要的朋友可以參考下2014-10-10JavaScript入門教程(9) Document文檔對(duì)象
Document文檔對(duì)象是JavaScript中window和frames對(duì)象的一個(gè)屬性,是顯示于窗口或框架內(nèi)的一個(gè)文檔。2009-01-01深入理解JavaScript系列(40):設(shè)計(jì)模式之組合模式詳解
這篇文章主要介紹了深入理解JavaScript系列(40):設(shè)計(jì)模式之組合模式詳解,組合模式(Composite)將對(duì)象組合成樹形結(jié)構(gòu)以表示“部分-整體”的層次結(jié)構(gòu),組合模式使得用戶對(duì)單個(gè)對(duì)象和組合對(duì)象的使用具有一致性,需要的朋友可以參考下2015-03-03