Es ist diese Art von blinder Forschung und Prüfung, die keine Grundlage in Prinzipien hat, die mich verwirrt hat. Ist es tatsächlich notwendig, dies zu tun, wenn man die Prinzipien versteht? Führen Sie so viele Tests nacheinander durch und zeichnen Sie dann die Regeln für
var Die Regeln dafür
dies sind: Dies zeigt in der Methodenfunktion immer auf sich selbst und dies zeigt in der gewöhnlichen Funktion immer auf das 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 })();
Überraschenderweise ist das Ergebnis der letzten Warnung(b) immer noch 789. // Keine verdammte Überraschung!
// 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-Methode zum Löschen lokaler Variablen
alert('value:'+str+'\ttype:'+typeof(str)) //声明变量前,引用 var str="dd"; alert('value:'+str+'\ttype:'+typeof(str)) //声明并赋值变量后,引用 str=undefined; //删除局部变量 alert('value:'+str+'\ttype:'+typeof(str)) //取消变量后,引用,和第一个相同
Das obige ist der detaillierte Inhalt vonAnalysieren Sie globale und lokale JS-Variablen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!