JavaScript中的變量定義與儲(chǔ)存介紹
與C、Java等編程語言不同,JavaScript中的變量是無類型的,所有的變量定義使用的關(guān)鍵詞均為var:
var a;
var m, n;
var x=42, y="test";
如果定義變量后未對該變量進(jìn)行賦值,那么該變量的值為undefined。如上面代碼中的a、m、n三個(gè)變量的值均為undefined。
由于JS中變量是無類型的,因此完全可以對同一個(gè)變量進(jìn)行不同類型的賦值,如:
var b = "temp";
console.log(typeof b);//string
b = 108;
console.log(typeof b);//number
除了可以對同一變量進(jìn)行不同類型的賦值,JavaScript中還可以對變量進(jìn)行重復(fù)定義;如果這么做,則第一次之后的變量定義語句等價(jià)于賦值語句:
var c = "hello";
console.log(c);//hello
var c = true;
console.log(c);//true
在ECMAScript標(biāo)準(zhǔn)的嚴(yán)格模式(strict mode)下,所有的變量定義均需使用var關(guān)鍵詞。如果不使用嚴(yán)格模式,那么當(dāng)JS程序?qū)δ硞€(gè)未被定義過的變量進(jìn)行賦值時(shí),程序?qū)⒃贘S全局對象中創(chuàng)建一個(gè)名稱與該變量相同的屬性,也即創(chuàng)建一個(gè)新的全局變量。這種做法會(huì)帶來很多問題(比如,多個(gè)JS程序間產(chǎn)生全局變量污染等),給后期維護(hù)帶來不小的麻煩;因此在實(shí)際開發(fā)過程中,應(yīng)當(dāng)盡量避免使用這種做法。
變量的儲(chǔ)存
如果定義的變量為全局變量,同時(shí)在變量定義過程中沒有使用var關(guān)鍵詞,那么該變量會(huì)作為全局對象的屬性而存在,可以通過訪問this(全局對象)的相應(yīng)屬性而獲得,也可以通過使用delete關(guān)鍵詞將其從全局對象中刪除掉:
var e = "globalVariableValue";//defined outside of any function, it is a global variable, but does not store in "this"
f = "globalVariableValue2";
this.g = "globalVariableValue3";
console.log(this.e);//undefined
console.log(this.f);//globalVariableValue2
console.log(this.g);//globalVariableValue3
delete f;
delete g;
console.log(this.f);//undefined
console.log(this.g);//undefined
對于JavaScript中的每一次函數(shù)調(diào)用,JavaScript都會(huì)創(chuàng)建一個(gè)局部對象以儲(chǔ)存在該函數(shù)中定義的局部變量;如果在該函數(shù)內(nèi)部還有一個(gè)嵌套定義的函數(shù)(nested function),那么JavaScript會(huì)在已經(jīng)定義的局部對象內(nèi)部再定義一個(gè)嵌套局部對象。對于一個(gè)函數(shù),其內(nèi)部有多少層的嵌套函數(shù)定義,也就有多少層的嵌套局部對象。該局部對象稱為“函數(shù)調(diào)用對象”(ECMAScript 3中的“call object”,ECMAScript 5中改名為“declarative environment record”,但個(gè)人認(rèn)為還是ECMAScript 3中的名稱更容易理解一些)。
與全局對象this相反,JavaScript中不提供任何方式來訪問這些局部對象(函數(shù)調(diào)用對象)。因此,開發(fā)人員無法對這些局部對象進(jìn)行操作。不過,理解這些函數(shù)調(diào)用對象對于理解JavaScript中的一些概念會(huì)有很大的幫助,比如說變量的作用域和閉包。
相關(guān)文章
JavaScript前后端數(shù)據(jù)交互工具ajax使用教程
Ajax(Asynchronous?Javascript?And?XML),即是異步的JavaScript和XML,Ajax其實(shí)就是瀏覽器與服務(wù)器之間的一種異步通信方式2022-10-10利用JavaScript實(shí)現(xiàn)防抖節(jié)流函數(shù)的示例代碼
在開發(fā)中我們經(jīng)常會(huì)遇到一些高頻操作,比如:鼠標(biāo)移動(dòng),滑動(dòng)窗口,鍵盤輸入等等,節(jié)流和防抖就是對此類事件進(jìn)行優(yōu)化,降低觸發(fā)的頻率,以達(dá)到提高性能的目的。本文就教大家如何實(shí)現(xiàn)一個(gè)讓面試官拍大腿的防抖節(jié)流函數(shù),需要的可以參考一下2022-08-08javascript實(shí)現(xiàn) 在光標(biāo)處插入指定內(nèi)容
javascript實(shí)現(xiàn) 在光標(biāo)處插入指定內(nèi)容...2007-05-05谷歌瀏覽器 insertCell與appendChild的區(qū)別
table中增加單元格時(shí) 在谷歌瀏覽器中使用insertCell方法增加列時(shí),顯示結(jié)果的先后順序與程序執(zhí)行的先后順序相反2009-02-02