国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當(dāng)前位置: 首頁 - 科技 - 知識(shí)百科 - 正文

JavaScript運(yùn)行原理詳細(xì)分析解答

來源:懂視網(wǎng) 責(zé)編:小采 時(shí)間:2020-11-27 19:48:44
文檔

JavaScript運(yùn)行原理詳細(xì)分析解答

JavaScript運(yùn)行原理詳細(xì)分析解答:本篇文章給大家從理論詳細(xì)分析了JavaScript運(yùn)行原理以及知識(shí)點(diǎn)分享,對此有興趣的學(xué)習(xí)下吧。JavaScript是一種基于對象的動(dòng)態(tài)、弱類型腳本語言(以下簡稱JS),是一種解釋型語言,和其他的編程語言不同,如java/C++等編譯型語言,這些語言在代碼執(zhí)行前會(huì)進(jìn)行通
推薦度:
導(dǎo)讀JavaScript運(yùn)行原理詳細(xì)分析解答:本篇文章給大家從理論詳細(xì)分析了JavaScript運(yùn)行原理以及知識(shí)點(diǎn)分享,對此有興趣的學(xué)習(xí)下吧。JavaScript是一種基于對象的動(dòng)態(tài)、弱類型腳本語言(以下簡稱JS),是一種解釋型語言,和其他的編程語言不同,如java/C++等編譯型語言,這些語言在代碼執(zhí)行前會(huì)進(jìn)行通

本篇文章給大家從理論詳細(xì)分析了JavaScript運(yùn)行原理以及知識(shí)點(diǎn)分享,對此有興趣的學(xué)習(xí)下吧。

JavaScript是一種基于對象的動(dòng)態(tài)、弱類型腳本語言(以下簡稱JS),是一種解釋型語言,和其他的編程語言不同,如java/C++等編譯型語言,這些語言在代碼執(zhí)行前會(huì)進(jìn)行通篇編譯,先編譯成字節(jié)碼(機(jī)器碼)。然后在執(zhí)行。而JS不是這樣做的,JS是不需要編譯成中間碼,而是可以直接在瀏覽器中運(yùn)行,JS運(yùn)行過程可分為兩個(gè)階段,編譯和執(zhí)行。(可參考你不知道的JS這本書),當(dāng)JS控制器轉(zhuǎn)到一段可執(zhí)行的代碼時(shí)(這段可執(zhí)行代碼就是編譯階段生成的),會(huì)創(chuàng)建與之對應(yīng)的執(zhí)行上下文(Excution Context簡稱EC)。執(zhí)行上下文可以理解為執(zhí)行環(huán)境(執(zhí)行上下文只能由JS解釋器創(chuàng)建,也只能由JS解釋器使用,用戶是不可以操作該‘對象'的)。

JS中的執(zhí)行環(huán)境分為三類:

  • 全局環(huán)境:當(dāng)JS引擎進(jìn)入一個(gè)代碼塊時(shí),如遇到<script>xxx</script>標(biāo)簽,就是進(jìn)入一個(gè)全局執(zhí)行環(huán)境

  • 函數(shù)環(huán)境:當(dāng)一個(gè)函數(shù)被調(diào)用時(shí),在函數(shù)內(nèi)部就形成了一個(gè)函數(shù)執(zhí)行環(huán)境

  • eval():把字符串單做JS代碼執(zhí)行,不推薦使用

  • 在一段JS代碼中可能會(huì)產(chǎn)生多個(gè)執(zhí)行上下文,在JS中用棧這種數(shù)據(jù)結(jié)構(gòu)來管理執(zhí)行上下文,棧的特點(diǎn)是“先進(jìn)后出,后進(jìn)先出”,這種棧稱之為函數(shù)調(diào)用棧。

    執(zhí)行上下文的特點(diǎn)

  • 棧底永遠(yuǎn)是全局執(zhí)行上下文,有且僅有一個(gè)

  • 全局執(zhí)行上下文只有在瀏覽器關(guān)閉時(shí),才會(huì)彈出棧

  • 其他的執(zhí)行上下文的數(shù)量沒有限制

  • 棧頂永遠(yuǎn)是當(dāng)前活動(dòng)執(zhí)行上下文,其余的都處于等待狀態(tài)中,一旦執(zhí)行完畢,立即彈出棧,然后控制權(quán)交回下一個(gè)執(zhí)行上下文

  • 函數(shù)只有在每次被調(diào)用時(shí),才會(huì)為其創(chuàng)建執(zhí)行上下文,函數(shù)被聲明時(shí)是沒有的。

  • 執(zhí)行上下文可以形象的理解為一個(gè)普通的JS對象,一個(gè)執(zhí)行上下文的生命周期大概包含兩個(gè)階段:

    創(chuàng)建階段

    此階段主要完成三件事件,1、創(chuàng)建變量對象 2、建立作用域鏈 3、確定this指向

    執(zhí)行階段

    此階段主要完成變量賦值、函數(shù)調(diào)用、其他操作

    變量對象(VO)的創(chuàng)建過程

  • 1、根據(jù)函數(shù)參數(shù),創(chuàng)建并初始化arguments對象,給arguments對象添加屬性"0","1","2","3"等屬性,其初始值為undefined,并設(shè)置arguments.length值為實(shí)際傳入?yún)?shù)的個(gè)數(shù)。

  • 2、查找function函數(shù)聲明,在變量對象上添加屬性,屬性名就是函數(shù)名,屬性值就是函數(shù)的引用值,如果已經(jīng)存在同名的,則直接覆蓋

  • 3、查找var變量聲明(查找變量時(shí),會(huì)把函數(shù)的參數(shù)等價(jià)于var聲明,所以在VO中也會(huì)添加和參數(shù)名一樣的屬性,初始值也是undefined),在變量對象添加屬性,屬性名就是變量名,屬性值是undefined,如果已經(jīng)存在同名的,則不處理

  • 如果存在同名標(biāo)識(shí)符(函數(shù)、變量),則函數(shù)可以覆蓋變量,函數(shù)的優(yōu)先級(jí)高于變量

    變量對象(OV)和激活對象(AO)是同一個(gè)東西,在不同時(shí)期的兩種叫法。在創(chuàng)建時(shí)期叫變量對象,在執(zhí)行時(shí)期叫激活對象

    以如下代碼為例

    編譯階段

    當(dāng)JS控制器轉(zhuǎn)到這一段代碼時(shí),會(huì)創(chuàng)建一個(gè)執(zhí)行上下文,G_EC

    執(zhí)行上下文的結(jié)構(gòu)大概如下:

    執(zhí)行上下文一旦創(chuàng)建完畢,就立馬被壓入函數(shù)調(diào)用棧中,此時(shí)解釋器會(huì)悄悄的做一件事情,就是給當(dāng)前VO中的函數(shù)添加一個(gè)內(nèi)部屬性[[scope]],該屬性指向上面的作用域鏈。

    執(zhí)行階段

    一行一行執(zhí)行代碼,當(dāng)遇到一個(gè)表達(dá)式時(shí),就會(huì)去當(dāng)前作用域鏈的中查找VO對象,如果找到則返回,如果找不到,則繼續(xù)查找下一個(gè)VO對象,直至全局VO對象終止。

    此階段可以有變量賦值,函數(shù)調(diào)用等操作,當(dāng)解釋器遇到g_fn()時(shí),就知道這是一個(gè)函數(shù)調(diào)用,然后立即為其創(chuàng)建一個(gè)函數(shù)執(zhí)行上下文,fn_EC,該上下文fn_EC同樣有兩個(gè)階段

    分別是創(chuàng)建階段和執(zhí)行階段。

    在創(chuàng)建階段,對于函數(shù)執(zhí)行上下文,在創(chuàng)建變量對象時(shí),會(huì)多創(chuàng)建一個(gè)arguments對象,然后為arguments對象添加屬性:"0","1", "2"其初始值為undefined,

  • 查找function函數(shù)聲明

  • 查找var變量聲明

  • 上面是我整理給大家的,希望今后會(huì)對大家有幫助。

    相關(guān)文章:

    p5.js實(shí)現(xiàn)黃金螺旋動(dòng)畫

    JS中事件委托使用詳解

    Vue.js里computed與methods使用詳解

    聲明:本網(wǎng)頁內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問題請及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

    文檔

    JavaScript運(yùn)行原理詳細(xì)分析解答

    JavaScript運(yùn)行原理詳細(xì)分析解答:本篇文章給大家從理論詳細(xì)分析了JavaScript運(yùn)行原理以及知識(shí)點(diǎn)分享,對此有興趣的學(xué)習(xí)下吧。JavaScript是一種基于對象的動(dòng)態(tài)、弱類型腳本語言(以下簡稱JS),是一種解釋型語言,和其他的編程語言不同,如java/C++等編譯型語言,這些語言在代碼執(zhí)行前會(huì)進(jìn)行通
    推薦度:
    標(biāo)簽: js 詳細(xì) 解析
    • 熱門焦點(diǎn)

    最新推薦

    猜你喜歡

    熱門推薦

    專題
    Top
    主站蜘蛛池模板: 亚洲日韩图片专区第1页 | 国产第二十页 | 亚洲国产成人精品一区二区三区 | 亚洲一区二区三区精品视频 | 久久久久久国产精品免费 | 亚洲欧洲高清有无 | 国产精选视频 | 在线综合亚洲欧美自拍 | 最新国产精品亚洲二区 | 免费看啪啪网站 | 成人黄色一级视频 | 精品久久中文网址 | 亚洲视频入口 | 国产精品亚洲一区二区三区 | 国产区一区二 | 国产精品亚洲综合 | 91久久精品国产性色也91久久 | 中文国产成人精品久久一 | 中文字幕久久久久一区 | 一区二区视频在线观看 | 国产一级视频在线观看 | 欧美国产日韩一区二区三区 | 免费在线国产视频 | 久久久久久亚洲精品影院 | 视频精品一区二区三区 | 国产色综合久久无码有码 | 国产福利一区二区三区在线视频 | 久久久一区二区三区不卡 | 日本三级韩国三级韩级在线观看 | 国产精品久久久久久久专区 | 护士精品一区二区三区 | 91狠狠干 | 国产精品v一区二区三区 | 午夜看一级特黄a大片黑 | 久久国产精品久久久久久久久久 | 国产网站在线免费观看 | 欧美 日韩 视频 | 欧美人伦 | 色婷婷综合久久久久中文一区二区 | 亚洲精品一| 97成人免费视频 |