這篇文章主要介紹了javascript 顯示全域變數與隱式全域變數的差異,需要的朋友可以參考下
在JavaScript中,全域變數有兩種宣告方式
使用var 顯示宣告的全域變數
不使用var 宣告的隱式全域變數
兩者的差別在於是否能透過delete 運算元刪除
先看一段程式碼
var a = 'a'; // 显式声明的全局变量 b = 'b'; // 隐式声明的全局变量 console.log(a); // a console.log(b); // b console.log(window.a); // a console.log(window.b); // b
嘗試用delete 刪除
// 显式声明的全局变量不能被删除 delete a; // 返回 false // 隐式声明的全局变量可以被删除 delete b; // 返回 true // 删除情况 console.log(typeof a); // string console.log(typeof b); // undefined
Object.getOwnPropertyDescriptor(window, a); // {value: "a", writable: true, enumerable: true, configurable: false} Object.getOwnPropertyDescriptor(window, b); // {value: "b", writable: true, enumerable: true, configurable: true}
b = 'b'; var descriptor = Object.getOwnPropertyDescriptor(window, b); descriptor.configurable = false; Object.defineProperty(window, b, descriptor); delete b; // 返回 false
// 定义三个全局变量 var global_var = 1; global_novar = 2; // 反面教材 (function () { global_fromfunc = 3; // 反面教材 }()); // 试图删除 delete global_var; // false delete global_novar; // true delete global_fromfunc; // true // 测试该删除 typeof global_var; // "number" typeof global_novar; // "undefined" typeof global_fromfunc; // "undefined"
JavaScript之全域變數和隱式全域變數隱式全域變數和明確定義的全域變數間有些小的差異,就是透過delete運算子讓變數未定義的能力。
1、透過var建立的全域變數(在任何函數以外的程式中建立)是不能被刪除的。
var global = (function () { return this; }());
rrreee
這種方法可以隨時獲得全域對象,因為其在函數中被當做函數呼叫了(不是透過new構造),this總是指向全域物件。實際上這個病不適用於ECMAScript 5嚴格模式,所以,在嚴格模式下時,你必須採取不同的形式。例如,你正在開發一個JavaScript庫,你可以將你的程式碼包裹在一個即時函數中,然後從 全域作用域中,傳遞一個引用指向this作為你即時函數的參數。 以上就是javascript 顯示全域變數與隱式全域變數的差別,兩者的根本差別在於明確宣告的變數不可配置,不能透過delete 運算子刪除更多javascript 顯示全域變數與隱式全域變數的區別相關文章請關注PHP中文網! 🎜