您好,登錄后才能下訂單哦!
如何在JavaScript中聲明變量?很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學(xué)習(xí)下,希望你能有所收獲。
javascript是一種動態(tài)類型、弱類型的語言,基于對象和事件驅(qū)動并具有相對安全性并廣泛用于客戶端網(wǎng)頁開發(fā)的腳本語言,同時也是一種廣泛用于客戶端Web開發(fā)的腳本語言。它主要用來給HTML網(wǎng)頁添加動態(tài)功能,現(xiàn)在JavaScript也可被用于網(wǎng)絡(luò)服務(wù)器,如Node.js。
JavaScript的變量聲明
JavaScript的變量聲明語句無論出現(xiàn)在何處,都會先于其他代碼首先被執(zhí)行。使用var關(guān)鍵詞聲明變量的作用域是當(dāng)前的執(zhí)行上下文,有可能是外圍函數(shù),或者,當(dāng)變量聲明在函數(shù)體之外時,則為全局變量。
向一個未聲明變量賦值會隱式地將其創(chuàng)建為一個全局變量(它變成了全局對象的一個屬性)。聲明變量與未聲明變量之間的區(qū)別為:
1. 聲明變量的作用范圍限定在其執(zhí)行的上下文環(huán)境中。未聲明的變量總是全局的。
function x() { y = 1; // Throws a ReferenceError in strict mode var z = 2; } x(); console.log(y); // logs "1" console.log(z); // Throws a ReferenceError: z is not defined outside x
2. 聲明變量在其他代碼執(zhí)行之前創(chuàng)建。未聲明的變量在其賦值語句執(zhí)行之前都是不存在的。
console.log(a); // Throws a ReferenceError. console.log('still going...'); // Never executes. var a; console.log(a); // logs "undefined" or "" depending on browser. console.log('still going...'); // logs "still going...".
3. 聲明變量是執(zhí)行上下文(函數(shù)或者全局)的不可配置的屬性。而未聲明變量是可配置的(例如,可以被delete)
var a = 1; b = 2; delete this.a; // Throws a TypeError in strict mode. Fails silently otherwise. delete this.b; console.log(a, b); // Throws a ReferenceError. // The 'b' property was deleted and no longer exists.
由于以上三點不同,使用未聲明變量可能會帶來意想不到的結(jié)果。因此建議無論是全局變量還是局部變量,在使用前都要聲明。在ECMAScript5的嚴格模式下,對未聲明變量賦值會拋出一個錯誤。
聲明提前(var hoisting):
JavaScript的函數(shù)作用域是指在函數(shù)內(nèi)聲明的所有變量在函數(shù)體內(nèi)是始終可見的。有趣的是,這意味著變量甚至可以先使用,后聲明。
JavaScript的這一特性被非正式地稱為聲明提前(hoiosting),即JavaScript函數(shù)中所有變量的聲明都被“提前”至函數(shù)體的頂部。
(“聲明提前”的操作是在JavaScript引擎的“預(yù)編譯”時進行的,即在代碼運行之前)
例如下面的JavaScript代碼:
var scope = "global"; function f() { alert(scope); var scope = "local"; //覆蓋全局變量 alert(scope); }
讀者可能誤以為函數(shù)f的第一個alert會輸出"global",因為代碼此時還沒有執(zhí)行到var語句聲明局部變量的代碼行。
其實不然,由于函數(shù)作用域的特性,局部變量在整個函數(shù)體內(nèi)始終是有定義的,亦即,在函數(shù)體內(nèi)局部變量覆蓋了同名的全局變量。盡管如此,只有程序執(zhí)行到var語句時,局部變量才會被賦值。因此上述過程等價于,將函數(shù)體內(nèi)的變量聲明“提前”至函數(shù)體頂部,而變量的初始化保留在原處。
function f() { var scope; //函數(shù)體頂部聲明局部變量 alert(scope); //輸出"undefined" scope = "local"; //變量初始化賦值 alert(scope); //輸出"local" }
看完上述內(nèi)容是否對您有幫助呢?如果還想對相關(guān)知識有進一步的了解或閱讀更多相關(guān)文章,請關(guān)注億速云行業(yè)資訊頻道,感謝您對億速云的支持。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。