欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript的變量聲明與聲明提前用法實例分析

 更新時間:2019年11月26日 09:57:38   作者:在線瘋狂  
這篇文章主要介紹了JavaScript的變量聲明與聲明提前用法,結(jié)合實例形式分析了JavaScript變量聲明與聲明提前相關(guān)原理、用法及操作注意事項,需要的朋友可以參考下

本文實例講述了JavaScript的變量聲明與聲明提前用法。分享給大家供大家參考,具體如下:

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的嚴(yán)格模式下,對未聲明變量賦值會拋出一個錯誤。

聲明提前(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"
}

基于此原因,建議將變量的聲明都放在作用域的頂部(全局代碼的頂端,或者函數(shù)代碼的開始),從而清楚地區(qū)分變量的作用域,哪些是函數(shù)作用域,哪些在作用域鏈上解析。

參考資料:

1. https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Statements/var

2. 《JavaScript權(quán)威指南》 第6版 中文版

更多關(guān)于JavaScript相關(guān)內(nèi)容可查看本站專題:《JavaScript常用函數(shù)技巧匯總》、《javascript面向?qū)ο笕腴T教程》、《JavaScript錯誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》及《JavaScript數(shù)學(xué)運算用法總結(jié)

希望本文所述對大家JavaScript程序設(shè)計有所幫助。

相關(guān)文章

  • 淺談JS中小數(shù)相加不精確的原因

    淺談JS中小數(shù)相加不精確的原因

    Javascript在處理數(shù)字問題時,我們有可能遇到小數(shù)相加不準(zhǔn)確的問題,本文主要介紹了淺談JS中小數(shù)相加不精確的原因,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2023-04-04
  • JS實現(xiàn)表單中checkbox對勾選中增加邊框顯示效果

    JS實現(xiàn)表單中checkbox對勾選中增加邊框顯示效果

    這篇文章主要介紹了JS實現(xiàn)表單中checkbox對勾選中增加邊框顯示效果,可實現(xiàn)點擊后圖片增加邊框及勾選的功能,非常簡潔實用,需要的朋友可以參考下
    2015-08-08
  • JavaScript trim 實現(xiàn)去除字符串首尾指定字符的簡單方法

    JavaScript trim 實現(xiàn)去除字符串首尾指定字符的簡單方法

    下面小編就為大家?guī)硪黄狫avaScript trim 實現(xiàn)去除字符串首尾指定字符的簡單方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-12-12
  • JavaScript實現(xiàn)動態(tài)表格的方法詳解

    JavaScript實現(xiàn)動態(tài)表格的方法詳解

    這篇文章主要為大家介紹了JavaScript實現(xiàn)動態(tài)表格的方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-01-01
  • 復(fù)雜的javascript窗口分幀解析

    復(fù)雜的javascript窗口分幀解析

    這篇文章主要為大家詳細(xì)解析了復(fù)雜的javascript窗口分幀,什么是窗口分幀,JavaScript中幀窗口之間的關(guān)系,感興趣的小伙伴們可以參考一下
    2016-02-02
  • 關(guān)于ES6字符串的擴展詳解

    關(guān)于ES6字符串的擴展詳解

    es6這個String對象倒是擴展了不少方法,但是很多都是跟字符編碼相關(guān),下面這篇文章主要給大家介紹了關(guān)于ES6字符串?dāng)U展的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-08-08
  • JS實現(xiàn)十字坐標(biāo)跟隨鼠標(biāo)效果

    JS實現(xiàn)十字坐標(biāo)跟隨鼠標(biāo)效果

    這篇文章給大家分享一下通過JS實現(xiàn)十字坐標(biāo)跟隨鼠標(biāo)效果的代碼,有需要的朋友參考學(xué)習(xí)下吧。
    2017-12-12
  • JS中的6種打斷點的方式實例總結(jié)

    JS中的6種打斷點的方式實例總結(jié)

    斷點調(diào)試是啥?難不難? 斷點調(diào)試其實并不是多么復(fù)雜的一件事,簡單的理解無外呼就是打開瀏覽器,打開sources找到j(luò)s文件,在行號上點一下罷了,下面這篇文章主要給大家介紹了關(guān)于JS中6種打斷點方式的相關(guān)資料,需要的朋友可以參考下
    2022-04-04
  • js判斷兩個字符串是否相等的兩種方法

    js判斷兩個字符串是否相等的兩種方法

    昨天用Ajax作驗證,在前臺JS中判斷返回的字符串的值與給定的值是否相等,索性給大家總結(jié)下,這篇文章主要給大家介紹了關(guān)于js判斷兩個字符串是否相等的兩種方法,需要的朋友可以參考下
    2023-05-05
  • 微信小程序上傳圖片到服務(wù)器實例代碼

    微信小程序上傳圖片到服務(wù)器實例代碼

    這篇文章主要介紹了微信小程序上傳圖片到服務(wù)器的實例代碼,在文章給大家補充介紹了微信小程序上傳一或多張圖片 的方法,本文給大家介紹的非常詳細(xì),具有參考借鑒加載,需要的朋友可以參考下
    2017-11-11

最新評論