400-650-7353
您所在的位置:首頁 > IT干貨資料 > web前端 > 【Web前端基礎知識】預解析(變量提升)

【Web前端基礎知識】預解析(變量提升)

  • 發布: Web前端培訓
  • 來源:Web前端干貨資料
  • 2020-12-18 16:18:48
  • 閱讀()
  • 分享
  • 手機端入口

今天為大家介紹一下一下JavaScript中的預解析(變量提升)。從什么是預解析及變量的預解析和函數的預解析及加載流程進行學習(注意:我們這里說的ES5中的預解析)。

什么是解析

首先代碼執行肯定需要一個執行環境,瀏覽器會提供一個供javaScript執行的全局作用域window。但是在javaScript執行之前會進行預解析,又稱之為變量提升。預解析可以分為兩部分:

- 聲明(declare): var a; 簡單的去理解聲明就是我們聲明一個變量沒有賦值;

- 定義(defined):a= 100; 定義相當于給這個變量進行賦值;

在javaScript執行之前瀏覽器會把全局作用域下所有帶有var和function關鍵字的進行預解析(注意是帶有var和function關鍵字的),這也就是為什么我們學習預解析去學習變量的預解析及函數的預解析原因,變量的預解析和函數的預解析存在一定的區別如下:

- var :在預解析的時候只聲明不定義

- function:在預解析的時候聲明+定義都已經完成了

變量的預解析

現在有如下代碼:

  1. console.log(a);//undefined   在代碼執行之前進行預解析  只聲明沒有定義只是undefined  
  2. var a = 10
  3. console.log(a);//10   

為了方便我們理解如圖:

這也就是為什么在我們看到var a = 10;之前去輸出a沒有報錯而是輸出undefined;聲明一個變量沒有進行賦值那么就是undefined;

函數的預解析及加載流程

前面我們說過了函數再預解析的時候聲明+定義都已經完成了,現在有如下代碼:

  1. //定義一個函數sum 
  2. function sum(){ 
  3.    Console.log(“javascript”); 
  4. sum();//->javascript    每次調用都重新執行 
  5. sum();//->javascript    每次調用都重新執行 
  6. sum();//->javascript    每次調用都重新執行 

我們先去看下函數的加載流程:

1. 函數在預解析的時候聲明+定義都已經完成了

2. 因為函數是引用數據類型,會新開辟一個堆內存空間,將函數以字符串的形式進行存儲,并且會給這堆個內存空間分配一個內存地址比如xxxfff000

3.函數的調用的時候,會開辟一個新的私有作用域,將函數體中內容從上到下依次執行

4.函數每一次調用都是相互獨立的,并且函數執行完畢之后自動銷毀

方便大家理解加載流程如圖所示:

從上圖可以分析出函數先進性了預解析,在預解析的時候聲明+定義都已經完成了,并且開辟了一塊堆內存空間將函數以字符串的形式進行存儲,并且給這塊堆內存分配一個內存地址便于我們使用的時候去找到它,因為這個時候函數以字符串的形式進行存儲,也就是為什么函數定義函數不去調用是不能執行的。當我們調用的時候發現,開辟了個一個新的私有作用域,函數體從上到下去執行,并且每一次調用都會形成新的私有作用域,所以是相互獨立的,并且每一個私有作用執行完畢就自動銷毀了,是瀏覽器內置的垃圾回收機制。這樣保證了性能優化。

文章“【Web前端基礎知識】預解析(變量提升)”已幫助

>>本文地址:http://www.028benet.com/zhuanye/2020/63244.html

THE END  

聲明:本站稿件版權均屬中公教育優就業所有,未經許可不得擅自轉載。

1 您的年齡

2 您的學歷

3 您更想做哪個方向的工作?

獲取測試結果
  • 大前端大前端
  • 大數據大數據
  • 互聯網營銷互聯網營銷
  • JavaJava
  • Linux云計算Linux
  • Python+人工智能Python
  • 嵌入式物聯網嵌入式
  • 全域電商運營全域電商運營
  • 軟件測試軟件測試
  • 室內設計室內設計
  • 平面設計平面設計
  • 電商設計電商設計
  • 網頁設計網頁設計
  • 全鏈路UI/UE設計UI設計
  • VR/AR游戲開發VR/AR
  • 網絡安全網絡安全
  • 新媒體與短視頻運營新媒體
  • 直播帶貨直播帶貨
  • 智能機器人軟件開發智能機器人
 

快速通道fast track

近期開班時間TIME

主站蜘蛛池模板: www亚洲视频| 免费v片视频在线观看视频| 亚洲av综合色区无码一区爱av| 97青青草视频| 欧美高清熟妇啪啪内射不卡自拍| 女人体1963毛片a级| 国语自产偷拍精品视频偷| 人妻少妇一区二区三区| WWW夜片内射视频在观看视频 | 999任你躁在线精品免费不卡| 激情内射亚洲一区二区三区爱妻 | 葫芦里不卖药葫芦娃app| 欧美特黄三级在线观看| 国产精品第一页第一页| 免费的一级毛片| 99精品人妻少妇一区二区| 欧美日韩国产色| 成人免费在线看片| 免费看美女隐私全部| AV无码久久久久不卡蜜桃| 欧美日韩国产精品va| 国产精品99久久久精品无码| 做zm被逮判几年| 91福利精品老师国产自产在线| 精品午夜久久网成年网| 日韩三级电影院| 嘟嘟嘟在线视频免费观看高清中文| 亚洲一区爱区精品无码| 麻豆麻豆必出精品入口| 日日噜噜夜夜狠狠va视频| 北条麻妃一本到高清在线观看| baoyu116.永久免费视频| 欧美熟妇另类久久久久久不卡| 国产欧美精品一区二区三区-老狼| 久久婷婷久久一区二区三区| 耻辱にまみれた失禁调教| 太粗太长岳受不了了| 亚洲另类激情综合偷自拍图| 香蕉久久人人爽人人爽人人片av| 成人最新午夜免费视频| 国产v日韩v欧美v精品专区|