国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

JavaScript的變量聲明提升問題淺析(Hoisting)

2019-11-19 18:45:39
字體:
來源:轉載
供稿:網友

一、變量聲明提升

      hoisting 英[‘hɔɪstɪŋ] 美[‘hɔɪstɪŋ]

      n. 起重,提升

      v. 把…吊起,升起( hoist的現在分詞 )

先來看一個栗子

var cc = 'hello';function foo(){ console.log(cc); var cc = 'world'; console.log(cc);}foo();console.log(cc);

這里將會輸出 undefined'world' 'hello'

此處主要有兩個知識點:

      1、作用域

      2、變量聲明提升

JavaScript是一門解釋性語言,當代碼在解釋器(如Chrome的V8引擎)環境中執行時,會有一個預解析的過程,此時會將變量聲明和函數聲明提升至當前作用域的最前方,這個行為被稱為聲明提升(Hoisting)

再來看上面的例子,此代碼有兩層作用域,全局作用域和函數foo作用域,而foo中的變量聲明在預解析的過程中會被提升至函數作用域的前方,于是代碼就會變成這樣:

var cc = 'hello';function foo(){ var cc; console.log(cc); cc = 'world'; console.log(cc);}foo();console.log(cc);

當執行到第一個log時,變量cc只是進行了聲明,并未賦值,所以打印出的是undefined

二、 函數聲明提升

函數的聲明有兩種方式:函數聲明和函數表達式

// 函數聲明function foo(a, b) { return a + b;}// 函數表達式var foo = function(a, b) { return a + b;}

解析器在向執行環境中加載數據時,對函數聲明和函數表達式并非一視同仁。解析器會率先讀取函數聲明,并使其在執行任何代碼之前可用(可以訪問);至于函數表達式,則必須等到解析器執行到它所在的代碼行,才會真正被解釋執行。

當然,也可以函數聲明和函數表達式同時使用,如var a = function b(){} ,其結果是只具有函數表達式的作用,b會被自動忽略,所以只會發生變量提升效果。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 噶尔县| 日喀则市| 怀化市| 西藏| 濮阳市| 吴旗县| 济阳县| 梁河县| 资溪县| 北海市| 翁源县| 惠州市| 兴城市| 疏附县| 鲁山县| 阳泉市| 石河子市| 宝兴县| 舟山市| 合山市| 边坝县| 亳州市| 孟津县| 手游| 长垣县| 利辛县| 哈巴河县| 温宿县| 措美县| 揭东县| 孝感市| 惠安县| 玉树县| 龙川县| 北川| 鄱阳县| 诸暨市| 同江市| 句容市| 余姚市| 启东市|