DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> JS全局變量和局部變量最新解析
JS全局變量和局部變量最新解析
編輯:關於JavaScript     

就是這種盲目無原理依據的研究測試弄暈了我, 有必要這麼做嗎? 其實理解了原理就沒必要搞這麼多一個一個的試, 然後得出規律, ECMAScript規則都已經定義好了.

var的規則是: 使用var聲明變量就是內部變量, 否則就是先調用全局變量, 不管多少層函數.

this的規則是: method函數裡的this永遠指向自身, 普通函數的this永遠指向DOMWindow.

// GodDamnTest1
function Foo() { 
var a = 123; // 局部變量, 所有子函數的全局變量
this.a = 456; // 對象屬性
(function() { 
alert(a); // 123, 全局
alert(this.a); // undefined, 普通函數, this指向DOMWindow 
})(); 
} 
var f = new Foo(); 
// GodDamnTest2
function Foo() { 
var a = 123; 
this.a = 456; 
(function(a) { // 局部聲明
alert(a); // 456, 被函數局部聲明的a覆蓋了全局 
})(this.a); 
} 
var f = new Foo(); 
// GodDamnTest3
function Foo() { 
var a = 123; 
this.a = 456; 
(function() { 
alert(a); // 123, 全局
alert(this.a); // undefined, DOMWindow 
this.b = 789; // window.b = 789
})(); 
(function() { 
alert(this.b); // 789, window.b
})(); 
} 
var f = new Foo(); 
(function() { 
alert(this.b); // 789, window.b
})(); 

// GodDamnTest4
function Foo() { 
(function() { 
this.b = 789; // window.b = 789
})(); 
(function() { 
alert(this.b); // 789, window.b
var b = 0; 
alert(b); // 0, 這樣的測試也寫出來了!
})(); 
} 
var f = new Foo(); 
(function() { 
alert(this.b); // 789, window.b
alert(b); // 789, window.b
})(); 

令人意外的是,最後一個 alert(b),結果仍然是 789。 // no damn surprise at all!

// GodDamnTest5
function Foo() { 
(function() { 
this.b = 789; // window.b = 789
})(); 
(function() { 
alert(this.b); // 789, window.b
alert(b); // undefined, 全局
var b = 0; 
alert(b); // 0, 還有這種測試!
})(); 
} 
var f = new Foo(); 
(function() { 
alert(this.b); // 789, window.b
alert(b); // 789, window.b
})();

PS:JS刪除局部變量的方法

alert('value:'+str+'\ttype:'+typeof(str)) //聲明變量前,引用
var str="dd";
alert('value:'+str+'\ttype:'+typeof(str)) //聲明並賦值變量後,引用
str=undefined;             //刪除局部變量
alert('value:'+str+'\ttype:'+typeof(str)) //取消變量後,引用,和第一個相同

以上所述是小編給大家介紹的JS全局變量和局部變量最新解析,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對網站的支持!

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved