JavaScript中變量聲明有var和沒(méi)var的區(qū)別示例介紹
本文來(lái)論述JavaScript中變量聲明有var和沒(méi)var的區(qū)別,關(guān)于Js中的變量聲明的作用域是以函數(shù)為單位,所以我們經(jīng)常見(jiàn)到避免全局變量污染的方法是
(function(){ // ... })();
在函數(shù)內(nèi)部,有var和沒(méi)var聲明的變量是不一樣的。有var聲明的是局部變量,沒(méi)var的,聲明的全局變量,所以可以借此向外暴露接口東東。
在全局作用域內(nèi)聲明變量時(shí),有var 和沒(méi)var看起來(lái)都一樣,我們知道,聲明的全局變量,就是window的屬性,究竟是否一樣,我們通過(guò)ECMAScrpit5提供的屬性的特性查詢方法,來(lái)發(fā)現(xiàn)之間的區(qū)別。
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
通過(guò)上面,發(fā)現(xiàn),原來(lái)還是有差別的,我們?cè)儆胐elete刪除屬性來(lái)驗(yàn)證下,配置性為false的屬性無(wú)法刪除。也就是通過(guò)變量var聲明全局對(duì)象的屬性無(wú)法刪除,我們還會(huì)發(fā)現(xiàn)和函數(shù)聲明創(chuàng)建的全局對(duì)象屬性也無(wú)法刪除。
delete fff; // 無(wú)法刪除 delete ffa; // 可刪除 delete ffb; // 可刪除 delete ffc; // 可刪除
結(jié)論就是,加上var 和沒(méi)加 var的聲明全局變量是有區(qū)別的。
使用var語(yǔ)句重復(fù)聲明語(yǔ)句是合法且無(wú)害的。如果重復(fù)聲明且?guī)в匈x值,那么就和一般的賦值語(yǔ)句沒(méi)差別。如果嘗試讀取沒(méi)有聲明過(guò)的變量,Js會(huì)報(bào)錯(cuò)。
JavaScript的函數(shù)作用域內(nèi),聲明的變量或內(nèi)部函數(shù),在函數(shù)體內(nèi)都是可見(jiàn)的。意味著,函數(shù)在定義之前可能已經(jīng)可用。函數(shù)定義有兩種方式,一種是函數(shù)定義表達(dá)式,一種是函數(shù)聲明語(yǔ)句。
// 函數(shù)定義表達(dá)式 var fns = function (){ // ... }; // 函數(shù)聲明語(yǔ)句 function fns(){ // ... }
函數(shù)聲明語(yǔ)句“被提前”到外部腳本或外部函數(shù)作用域的頂部,所以以這種方式聲明的函數(shù),可以被再它定義之前出現(xiàn)的代碼所調(diào)用。而函數(shù)定義表達(dá)式中,變量的聲明被提前了,但是給變量的賦值是不會(huì)提前的,所以,以表達(dá)式方式定義的函數(shù)在函數(shù)定義之前無(wú)法調(diào)用。
(function() { testa(); // 打印出testa testb(); // 報(bào)錯(cuò):提示undefined is not a function console.log(testc); //undefined,如果移到上面就可以了 function testa() { console.log("testa"); } var testb = function() { console.log("tesb"); } var testc = "testc"; })();
當(dāng)然,我們聲明變量和函數(shù),必須遵守基本的規(guī)范,變量和函數(shù)聲明要提前。
相關(guān)文章
Javascript動(dòng)手實(shí)現(xiàn)call,bind,apply的代碼詳解
這篇文章主要為大家詳細(xì)介紹了Javascript動(dòng)手實(shí)現(xiàn)call,bind,apply的代碼,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助2022-02-02Jquery和JS用外部變量獲取Ajax返回的參數(shù)值的方法實(shí)例(超簡(jiǎn)單)
Jquery和JS用外部變量獲取Ajax返回的參數(shù)值的方法實(shí)例(超簡(jiǎn)單),需要的朋友可以參考一下2013-06-06js 實(shí)現(xiàn)css風(fēng)格選擇器(壓縮后2KB)
近日在做一些OA前端界面,為了更好管理頁(yè)面代碼想寫(xiě)個(gè)js選擇器,寫(xiě)著寫(xiě)著發(fā)現(xiàn)很費(fèi)力,索性在網(wǎng)上找找看,功夫不負(fù)有心人, 找到一個(gè)mini css選擇器,且性能不凡:以下代碼是壓縮后的,僅2KB2012-01-01ionic中的$ionicPlatform.ready事件中的通用設(shè)置
$ionicPlatform.ready事件是用于檢測(cè)當(dāng)前的平臺(tái)是否就緒的事件,相當(dāng)于基于document的deviceready事件, 在app中一些通用關(guān)于設(shè)備的設(shè)置必須在這個(gè)事件中處理2017-06-06JS效率個(gè)人經(jīng)驗(yàn)談(8-15更新),加入range技巧
JS效率個(gè)人經(jīng)驗(yàn)談(8-15更新),加入range技巧...2007-01-01關(guān)于javascript解決閉包漏洞的一個(gè)問(wèn)題詳解
閉包在JavaScript高級(jí)程序設(shè)計(jì)(第3版)中是這樣描述:閉包是指有權(quán)訪問(wèn)另一個(gè)函數(shù)作用域中的變量的函數(shù),下面這篇文章主要給大家介紹了關(guān)于javascript解決閉包漏洞的一個(gè)問(wèn)題的相關(guān)資料,需要的朋友可以參考下2022-11-11Javascript使用uploadify來(lái)實(shí)現(xiàn)多文件上傳
本篇文章主要介紹了Javascript使用uploadify來(lái)實(shí)現(xiàn)多文件上傳,具有一定的參考價(jià)值,有需要的可以了解一下。2016-11-11