自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

重學(xué)JavaScript第1集|變量提升

開發(fā) 前端
變量提升就好比JavaScript引擎用一個很小的代碼起重機(jī)將所有var聲明和function函數(shù)聲明都舉起到所屬作用域(所謂作用域,指的是可訪問變量和函數(shù)的區(qū)域)的最高處。

 變量提升就好比JavaScript引擎用一個很小的代碼起重機(jī)將所有var聲明和function函數(shù)聲明都舉起到所屬作用域(所謂作用域,指的是可訪問變量和函數(shù)的區(qū)域)的最高處。這句話的意思是:如果在函數(shù)體外定義函數(shù)或使用var聲明變量。則變量和函數(shù)的作用域會提升到整個代碼的最高處,此時任何地方訪問這個變量和調(diào)用這個函數(shù)都不會報(bào)錯;而在函數(shù)體內(nèi)定義函數(shù)或使用var聲明變量,變量和函數(shù)的作用域則會提升到整個函數(shù)的最高處,此時在函數(shù)體內(nèi)任何地方訪問這個變量和調(diào)用所定義的函數(shù)都不會報(bào)錯。

示例如下:

  1. console.log("gv1=" + gv); // 在聲明前訪問變量 
  2. show(); 
  3. var gv = "javascript"
  4. console.log("gv2=" + gv); 
  5. function(){ 
  6.  console.log("lv1= " + lv); 
  7.  vat lv = "js"
  8.  console.log("lv2=" + lv); 

輸出結(jié)果:

  1. gv1 = undefined; 
  2. lv1 = undefined; 
  3. lv2 = js; 
  4. gv2 = javasript; 

在上述代碼中,第一行迪馬以及show函數(shù)中的第一行代碼分別是在變量聲明前訪問了gv和lv變量,第二行代碼在函數(shù)定義前,調(diào)用了show函數(shù)。從輸出結(jié)果來看,上述代碼在聲明之前訪問變量以及在定義前調(diào)用函數(shù)完全沒問題,原因是變量提升。

上述代碼在代碼運(yùn)行前,經(jīng)過預(yù)解析處理后的代碼邏輯如下:

  1. var gv; // 變量聲明提升到當(dāng)前作用域的最高處 
  2. var show = function show (){ 
  3.  var lv; 
  4.  console.log("lv1=" + lv);//lv在聲明時沒有初始化,所以輸出undefined 
  5.  lv= "js"
  6.  console.log("lv2=" + lv); // 變量輸出賦予的值: js 
  7. console.log("gv1=" + gv1); // gv在聲明時沒有初始化,所以輸出undefined 
  8. gv = "javascript"
  9. console.log("gv2=" + gv);//變量輸出所賦予的值:javascript 

由上可見,正是因?yàn)関ar支持變量提升,所以可以在聲明前使用var聲明的變量,而let和const不支持變量提升,所以它們聲明的變量必須先聲明才可以使用。

一般來說,javascript代碼的執(zhí)行包括兩個過程:預(yù)解析處理過程和逐行解讀過程。在代碼逐行解讀前,javascript引擎需要進(jìn)行帶的預(yù)解析處理。在預(yù)解析過程中,當(dāng)前作用域中var變量聲明和函數(shù)定義將被提升到作用域的最高處。

 

責(zé)任編輯:姜華 來源: 前端歷劫之路
相關(guān)推薦

2020-10-14 15:15:28

JavaScript(

2021-09-07 09:53:42

JavaScript變量提升

2009-04-03 18:10:45

CCNP紅頭發(fā)視頻

2012-11-01 13:23:38

JSLintJavaScript代碼

2021-06-21 11:05:30

CSS前端代碼

2017-01-20 09:45:20

JavaScript代碼質(zhì)量

2010-04-01 14:35:36

Oracle綁定變量

2011-04-18 09:31:35

JavaScript

2010-10-27 13:55:01

memoization遞歸JavaScript

2015-06-30 10:36:00

2010-11-12 12:51:26

2013-09-05 10:07:34

javaScript變量

2011-10-08 14:09:27

JavaScript

2025-01-07 10:48:08

2024-06-11 00:09:00

JavaScript模式變量

2021-06-04 11:10:04

JavaScript開發(fā)代碼

2012-08-30 14:17:42

IBMdw

2012-07-04 15:09:43

ibmdw

2014-04-01 09:52:46

MySQL

2020-12-01 07:16:05

重學(xué)設(shè)計(jì)模式
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號