萬盛學電腦網

 萬盛學電腦網 >> 腳本專題 >> javascript >> JavaScript中的關鍵字VAR使用詳解 分享

JavaScript中的關鍵字VAR使用詳解 分享

JScript的語法教程裡面說在聲明變量時忽略var關鍵字是完全合法的。但是事實常常又證明想當然的結果是不可靠的。  

看看下面這幾個例子的結果就知道問題了:
這三個例子的執行結果分別是:

復制代碼 代碼如下:
Results#region Results
No.1
0
undefined
No.2
0
1
No.3
0
undefined
#endregion


原 來JavaScript的變量也是有作用域的,只是它非常的籠統,就分為全局變量和函數變量。在第二個例子中得到0和1,是因為所有的變量都是全局變量, 而且那個語句塊一共就定義了兩個變量。而第一個第三的函數外全局變量,確實說明var關鍵字有沒有都沒有關系。而函數內的var關鍵字就很關鍵了,它說明 第二個var01是函數內的變量,所以在初始化var01前輸出自然就是'undefined'了。
那麼函數裡面是不是就屏蔽掉了全局的 var01了呢?我們知道在C/C++可以使用::去訪問全局變量,那麼JavaScript可不可以呢?這裡其實我們只要明白了全局變量到底是什麼東 西,就好弄了。原來全局變量都是動態添加到Window對象的實例window上的屬性而以,所以我們只要在函數內 用:document.write(window.var01);就可以取到其值1了。同時在這個上下文中,function內的this也是指向的 window實例,我們也可以把引用寫成:this.var01。
順便說一下,重看JScript教程時,它說變量只能是[a-zA-Z_]+[a-zA-Z0-9_]*格式,可是'$'卻也可以作為變量名字符,而且還可以用在開頭,比如:$1234,更甚至於:$$$ 也是合法的變量名,faint。
我想知道是不是.在調用一個函數時,程序執行順序會先檢查函數內部變量中,有沒有關鍵字var. 然後中再根據檢查結果給不同的變量付予不同的作用域和變量值.因為我看到在這三個函數中,var01變量都是在輸出語句之後.

復制代碼 代碼如下:
function get_global_var(___name)
{
return eval(___name);
}
function set_global_var(___name,___value)
{
eval(___name+"=___value");
}
var aa=11;
Test();
WScript.Echo(aa);//22
function Test()
{
var aa=33;
WScript.Echo(get_global_var("aa"));//11
set_global_var("aa",22);
WScript.Echo(get_global_var("aa"));//22
WScript.Echo(aa);//33
}


在上面的例子中this從來就沒有指過Test,而一直都是WScript的實例。
如果我們寫一個語句:var test = new Test(); 這時Test裡的this就是指的Test的一個實例了,這個實例中如果要使用Global的變量,Lostinet給出的是一個方法。
不過最簡單還是把global傳入對象,這樣定義Test:

復制代碼 代碼如下:
function Test(global)
{
// ...
}


然後這樣創建實例:var test = new Test(this); 就可以在Test實例中使用global的對象和屬性了。
是不是這樣,在new的實例中,this就指實例,否則都指WScript?如果這樣的話,換了腳本引擎,是不是情況又會不同?這個是標准嗎?
new constructor[(arguments)];
new 運算符執行下面的任務:
·創建一個沒有成員的對象。
·為那個對象調用構造函數,傳遞一個指針給新創建的對象作為 this 指針。
·然後構造函數根據傳遞給它的參數初始化該對象。
要注意的是即使當前作用域內沒有調用new,但可能在其父作用域裡是調用了new的,所以“在new的實例中,this就指實例,否則都指WScript?”,前半句對,而後半句不一定。

copyright © 萬盛學電腦網 all rights reserved