JavaScript中有var和沒var的區別


 

Js中的變量聲明的作用域是以函數為單位,所以我們經常見到避免全局變量污染的方法是

(function(){

    // ...

})();

在函數內部,有var和沒var聲明的變量是不一樣的。有var聲明的是局部變量,沒var的,聲明的全局變量,所以可以借此向外暴露接口東東。

在全局作用域內聲明變量時,有var 和沒var看起來都一樣,我們知道,聲明的全局變量,就是window的屬性,究竟是否一樣,我們通過ECMAScrpit5提供的屬性的特性查詢方法,來發現之間的區別。

var fff = 2;

window.ffa = 3;

ffb = 4;

this.ffc = 4;

var ffftx = Object.getOwnPropertyDescriptor(window, 'fff'); //configurable:false,enumerable:true,value:2,writable:true

var ffatx = Object.getOwnPropertyDescriptor(window, 'ffa'); //configurable:true,enumerable:true,value:2,writable:true

var ffbtx = Object.getOwnPropertyDescriptor(window, 'ffb'); //configurable:true,enumerable:true,value:2,writable:true

var ffctx = Object.getOwnPropertyDescriptor(window, 'ffc'); //configurable:true,enumerable:true,value:2,writable:true

通過上面,發現,原來還是有差別的,我們再用delete刪除屬性來驗證下,配置性為false的屬性無法刪除。也就是通過變量var聲明全局對象的屬性無法刪除,我們還會發現和函數聲明創建的全局對象屬性也無法刪除。

delete fff; // 無法刪除

delete ffa; // 可刪除

delete ffb; // 可刪除

delete ffc; // 可刪除

結論就是,加上var 和沒加 var的聲明全局變量是有區別的。

使用var語句重復聲明語句是合法且無害的。如果重復聲明且帶有賦值,那么就和一般的賦值語句沒差別。如果嘗試讀取沒有聲明過的變量,Js會報錯。

JavaScript的函數作用域內,聲明的變量或內部函數,在函數體內都是可見的。意味着,函數在定義之前可能已經可用。函數定義有兩種方式,一種是函數定義表達式,一種是函數聲明語句。

// 函數定義表達式

var fns = function (){

    // ...

}

// 函數聲明語句

function fns(){

    // ...

}

函數聲明語句“被提前”到外部腳本或外部函數作用域的頂部,所以以這種方式聲明的函數,可以被再它定義之前出現的代碼所調用。而函數定義表達式中,變量的聲明被提前了,但是給變量的賦值是不會提前的,所以,以表達式方式定義的函數在函數定義之前無法調用。

(function() {

    testa(); // 打印出testa

    testb(); // 報錯:提示undefined is not a function

    console.log(testc); //打印出testc

    function testa() {

        console.log("testa");

    }

    var testb = function() {

        console.log("tesb");

    }

    var testc = "testc";

})();

當然,我們聲明變量和函數,必須遵守基本的規范,變量和函數聲明要提前。

以上函數定義,在《JavaScript權威指南》有涉及,借用了它的語句描述,此外http://www.cn-cuckoo.com/2008/12/26/on-javascript-function-271.html ,也有類似描述。

Ps:蠻崇拜《JavaScrpt高級程序設計》翻譯作者 李松峰,總是將JavaScript講解的如此深透,不過,在上面鏈接博文中,你會發現作用域的名詞又被李松峰大神隨便用了,以前他寫的關於原型的博文中看,作用域可不是這樣定義了。

 本文首發 http://www.cnblogs.com/sprying/p/3197196.html

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM