久久精品国产亚洲高清|精品日韩中文乱码在线|亚洲va中文字幕无码久|伊人久久综合狼伊人久久|亚洲不卡av不卡一区二区|精品久久久久久久蜜臀AV|国产精品19久久久久久不卡|国产男女猛烈视频在线观看麻豆

    1. <style id="76ofp"></style>

      <style id="76ofp"></style>
      <rt id="76ofp"></rt>
      <form id="76ofp"><optgroup id="76ofp"></optgroup></form>
      1. 千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

        手機(jī)站
        千鋒教育

        千鋒學(xué)習(xí)站 | 隨時(shí)隨地免費(fèi)學(xué)

        千鋒教育

        掃一掃進(jìn)入千鋒手機(jī)站

        領(lǐng)取全套視頻
        千鋒教育

        關(guān)注千鋒學(xué)習(xí)站小程序
        隨時(shí)隨地免費(fèi)學(xué)習(xí)課程

        當(dāng)前位置:首頁(yè)  >  技術(shù)干貨  > web前端教程之JavaScript的作用域

        web前端教程之JavaScript的作用域

        來(lái)源:千鋒教育
        發(fā)布人:小千
        時(shí)間: 2021-01-19 09:07:00 1611018420

              作為一個(gè)前端工程師,你必須對(duì)JavaScript的作用域不陌生,傳統(tǒng)常見(jiàn)的有函數(shù)級(jí)作用域,還有全局作用域,ES6 let const 的塊級(jí)作用域,其實(shí)還有一個(gè)你不知道的塊級(jí)作用域,今天小千就來(lái)給大家介紹一下。

              我們先來(lái)看看下面這個(gè)段代碼,請(qǐng)思考一下結(jié)果是什么。

        1

              想必你心中已經(jīng)有了結(jié)果,答案是 3  2

              你答對(duì)了嗎?答案結(jié)果是否有些意外呢?

              好了,我們來(lái)看看為什么會(huì)出現(xiàn)這個(gè)答案?首先我們需要先了解以下基本知識(shí)。

              聲明提前

              聲明提前指的是JS引擎在執(zhí)行之前對(duì)代碼進(jìn)行的預(yù)解析(為了提高執(zhí)行效率) 具體的來(lái)說(shuō)就是使用(var)聲明變量和(function)聲明的函數(shù)正預(yù)編譯階段將其提升到了作用域的頂部

              全局變量聲明

        2

              函數(shù)作用域變量聲明

        3

              函數(shù)聲明

        4

              函數(shù)表達(dá)式聲明

        5

              函數(shù)塊級(jí)作用域

              通過(guò)下面代碼我們可以知道 變量的聲明是沒(méi)有塊級(jí)作用域的,if語(yǔ)句塊中聲明的變量foo會(huì)提升到全局作用域并初始化值為undefined

        6

              我們?cè)倏纯春瘮?shù)的情況

        7

              上面這個(gè)例子告訴我們 函數(shù)foo提升到了if語(yǔ)句塊的頂部,但是沒(méi)有提升到全局作用域的頂部。但全局作用域中存有一個(gè)名為foo的變量 在代碼執(zhí)行后同步成了函數(shù)foo

              同步?為什么會(huì)有同步?我們來(lái)看看觀察上帝視角的神器 ———— 斷點(diǎn)調(diào)試。我這邊監(jiān)聽(tīng)了 foo 變量和 window.foo 大家請(qǐng)注意一下它的變化。同時(shí)我們也關(guān)注一下 Scope 作用域

              我們看到Scope中只有全局作用域 foo和window.foo的只都是undefined

        8

              代碼執(zhí)行到if語(yǔ)句塊中 我們?cè)賁cope中又發(fā)現(xiàn)了一個(gè)新的塊級(jí)作用域 當(dāng)前塊級(jí)作用域foo的值被賦值為一個(gè)函數(shù)(函數(shù)提升) 而全局作用域中的foo依舊是undefined

        9

              代碼繼續(xù)往后執(zhí)行 執(zhí)行函數(shù)的賦值 block作用域依然存在 我把幾個(gè)變量的值使用箭頭進(jìn)行了對(duì)應(yīng)

        10

              神奇的地方來(lái)了 在函數(shù)執(zhí)行賦值后 塊級(jí)作用域消失 而全局變量的foo同步成了剛才塊級(jí)作用域的foo

        11

              回歸原題

              我們對(duì)foo變量進(jìn)行隔行輸出 看看結(jié)果

        12

              結(jié)合上面斷點(diǎn)測(cè)試的結(jié)果大家可以發(fā)現(xiàn),函數(shù)在代碼塊中聲明會(huì)提前到塊級(jí)作用域頂部,預(yù)編譯結(jié)束后開(kāi)始執(zhí)行代碼 在執(zhí)行階段任然會(huì)執(zhí)行函數(shù)的賦值操作,其實(shí)是函數(shù)賦值的第二次執(zhí)行(第一次在預(yù)編譯階段) 第二次的賦值執(zhí)行的意義是確認(rèn)當(dāng)前 函數(shù)/全局 作用域能準(zhǔn)確的檢索到函數(shù) 所以講函數(shù)同步到了 當(dāng)前的函數(shù)或全局作用域中。

              好了本次解析就到這里,還有不明白的小伙伴可以copy代碼去進(jìn)行斷點(diǎn)測(cè)試,相信很快你能理解其中奧秘。 

              學(xué)習(xí)web前端,可以參考千鋒web前端培訓(xùn)班提供的web前端學(xué)習(xí)路線(xiàn),該學(xué)習(xí)路線(xiàn)對(duì)從零基礎(chǔ)小白到web前端初級(jí)開(kāi)發(fā)工程師,web前端高級(jí)開(kāi)發(fā)工程師,后面的web前端大神級(jí)開(kāi)發(fā)工程師都有一個(gè)明確清晰的指導(dǎo),根據(jù)千鋒web前端培訓(xùn)機(jī)構(gòu)提供的web前端學(xué)習(xí)路線(xiàn)圖可以讓你對(duì)學(xué)習(xí)web前端開(kāi)發(fā)需要掌握的知識(shí)有個(gè)清晰的了解,并快速入門(mén)web前端開(kāi)發(fā)。想要獲取前端完整學(xué)習(xí)路線(xiàn)和免費(fèi)的學(xué)習(xí)資料可以添加我們的web前端技術(shù)分享交流qq群:857920838  加群找群管理領(lǐng)取即可,等你來(lái)哦~~

        tags:
        聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
        10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
        請(qǐng)您保持通訊暢通,專(zhuān)屬學(xué)習(xí)老師24小時(shí)內(nèi)將與您1V1溝通
        免費(fèi)領(lǐng)取
        今日已有369人領(lǐng)取成功
        劉同學(xué) 138****2860 剛剛成功領(lǐng)取
        王同學(xué) 131****2015 剛剛成功領(lǐng)取
        張同學(xué) 133****4652 剛剛成功領(lǐng)取
        李同學(xué) 135****8607 剛剛成功領(lǐng)取
        楊同學(xué) 132****5667 剛剛成功領(lǐng)取
        岳同學(xué) 134****6652 剛剛成功領(lǐng)取
        梁同學(xué) 157****2950 剛剛成功領(lǐng)取
        劉同學(xué) 189****1015 剛剛成功領(lǐng)取
        張同學(xué) 155****4678 剛剛成功領(lǐng)取
        鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
        董同學(xué) 138****2867 剛剛成功領(lǐng)取
        周同學(xué) 136****3602 剛剛成功領(lǐng)取
        相關(guān)推薦HOT
        為什么sql語(yǔ)句不支持關(guān)系代數(shù)中的除法?

        為什么SQL語(yǔ)句不支持關(guān)系代數(shù)中的除法1. SQL和關(guān)系代數(shù)的關(guān)系:SQL是一種基于關(guān)系代數(shù)的查詢(xún)語(yǔ)言,它的設(shè)計(jì)初衷是為了能夠以一種更接近自然語(yǔ)言...詳情>>

        2023-10-14 04:07:35
        sql 怎么根據(jù)父id查詢(xún)下三級(jí)子集?

        一、概述處理樹(shù)形數(shù)據(jù)時(shí),我們常常需要根據(jù)父ID查詢(xún)其下的子集。本文將引導(dǎo)您如何使用SQL進(jìn)行這一操作,尤其是查詢(xún)下三級(jí)子集。二、查詢(xún)方法詳...詳情>>

        2023-10-14 03:59:07
        什么是分治算法,和遞歸有什么關(guān)系?

        分治算法是什么分治算法是一種算法設(shè)計(jì)思想,其主要思想是將一個(gè)復(fù)雜的問(wèn)題分解為兩個(gè)或更多相同或相似的子問(wèn)題,直到子問(wèn)題簡(jiǎn)單到可以直接解決...詳情>>

        2023-10-14 03:22:51
        為什么微服務(wù)一定要上Docker?

        為什么微服務(wù)一定要上Docker微服務(wù)作為一種軟件架構(gòu)模式,需要考慮的因素包括服務(wù)的獨(dú)立性、可擴(kuò)展性、可維護(hù)性和可移植性等。這其中,Docker的...詳情>>

        2023-10-14 03:15:33
        C++的traits技術(shù)到底是什么?

        在C++編程中,traits是一種編程技巧,其主要目的是在編譯時(shí)提供關(guān)于類(lèi)型的額外信息。它可以將類(lèi)型的一些特性(如其關(guān)聯(lián)類(lèi)型、屬性、函數(shù)等)抽...詳情>>

        2023-10-14 03:00:03
        快速通道
        景东| 德化县| 新兴县| 凉城县| 辉县市| 旬邑县| 池州市| 巫山县| 同德县| 兴山县| 武汉市| 左贡县| 安国市| 丹江口市| 喀什市| 西华县| 甘肃省| 晋中市| 涡阳县| 凤冈县| 昭苏县| 兰州市| 闸北区| 八宿县| 文水县| 罗江县| 偏关县| 泗洪县| 夏邑县| 光山县| 宁安市| 清流县| 周口市| 石渠县| 垦利县| 湖北省| 大化| 泸定县| 巧家县| 普陀区| 荆门市|