• <noscript id="ggggg"><dd id="ggggg"></dd></noscript>
    <small id="ggggg"></small> <sup id="ggggg"></sup>
    <noscript id="ggggg"><dd id="ggggg"></dd></noscript>
    <tfoot id="ggggg"></tfoot>
  • <nav id="ggggg"><cite id="ggggg"></cite></nav>
    <nav id="ggggg"></nav>
    成人黃色A片免费看三更小说,精品人妻av区波多野结衣,亚洲第一极品精品无码,欧美综合区自拍亚洲综合,久久99青青精品免费观看,中文字幕在线中字日韩 ,亚洲国产精品18久久久久久,黄色在线免费观看

    JavaScript 中的作用域、預解析以及變量提升

    2021-8-20    前端達人



    JavaScript 中的作用域、預解析以及變量提升

    作用域:變量的作用范圍

    局部作用域:函數內部



    在局部作用域聲明的變量稱為局部變量,局部變量只能在當前函數內部使用



    1)函數在執行的時候會在內存中開辟新空間



    2)當執行完畢函數之后,會關閉作用域空間(變量被銷毀)



    注意:形參也是局部變量



    function fn() {

        let b = 5

      // 局部訪問 變量 b 

        console.log(b) // 5

    }

    fn()

    // 全局訪問 變量 b

    console.log(b) // 訪問不存在的變量,報錯

    1

    2

    3

    4

    5

    6

    7

    8

    在控制臺打印得到如下結果







    全局作用域:函數外部



    1)在全局作用域聲明的變量是全局變量,全局變量可以在任何地方使用



    2)因為全局變量可以任何地方使用,所以要特別關注局部變量



    let a = 2

    function fn() {

        // 局部訪問 變量 a

        console.log(a) // 2

    }

    fn()

    // 全局訪問 變量 a

    console.log(a) // 2

    1

    2

    3

    4

    5

    6

    7

    8

    在控制臺打印得到如下結果







    函數內部之所以能夠訪問到變量 a ,是因為有一個作用鏈,函數內部訪問一個變量會先在自己的作用域內找,找不到會向上級作用域找,找不到就會報錯



    例如 如下代碼



    (找不到報錯的情況)



    function fn() {

        function fn1() {

            function fn2() {

                // 局部訪問 變量 a

        console.log(a) // 2

            }

            fn2()

        }

        fn1()

    }

    fn()

    1

    2

    3

    4

    5

    6

    7

    8

    9

    10

    11

    控制臺打印







    (全局變量局部訪問的情況)



    let a = 'hello javascript'

    function fn() {

        function fn1() {

            function fn2() {

                // 局部訪問 變量 a

        console.log(a) // hello javascript

            }

            fn2()

        }

        fn1()

    }

    fn()

    1

    2

    3

    4

    5

    6

    7

    8

    9

    10

    11

    12

    控制臺打印







    塊級作用域:類似局部作用域



    1)用 {} 包裹一塊



    2)let聲明變量具有塊級作用域,var聲明變量不具有塊級作用域



    例如



    (以字面量對象為例)



    let obj = {

        uname: '法外狂徒-張三',

        age: 68

    }

    1

    2

    3

    4

    想要訪問這個對象里面的屬性必須通過 obj.屬性,而不能直接訪問



    預解析

    預解析:在代碼執行之前把變量和函數會提前解析到當前作用域的最前面



    任何作用域在執行之前都要預解析 (函數優于變量)



    變量:帶有聲明的變量,只定義不賦值



    1)變量在聲明之前被訪問,變量的值為 undefined



    函數:帶有名字的函數,只定義不調用



    1)函數優于變量



    console.log(a) // undefined

    fn() // hello javascript



    function fn() {

        console.log('hello javascript')

    }

    var a = 2

    1

    2

    3

    4

    5

    6

    7

    代碼是自上而下執行,但是在代碼執行前會先進行代碼的預解析,把變量以及函數 聲明 提升到當前作用域的最前面,如上代碼,console.log(a) 會打印 undefined



    但是,注意!!!注意!!!



    變量必須是 var 聲明的才可以,如果是 let 聲明的變量會報錯



    圖 (var 聲明的 a)







    圖 (let 聲明的 a)







    變量提升

    預解析會引起變量的提升



    變量不聲明就輸出會報錯



    console.log(a) // 報錯

    1

    控制臺打印







    用 var 聲明



    console.log(a) // undefined



    var a = 'hello javascript'

    1

    2

    3

    控制臺打印 undefined ,我們知道變量定義不賦值會輸出 undefined,說明變量已經存在并且提升了,但是只提升了聲明沒有提升賦值,所以打印 undefined ,如果沒有提升的話,就會像上面一樣在執行 console.log(a) 的時候直接報錯



    結論:var 存在變量提升



    用 let 聲明



    console.log(a) // 報錯



    let a = 'hello javascript'

    1

    2

    3

    結論:let 不存在變量提升



    補充:

    申明變量:let \ var \ const



    1)let 聲明的變量不在window內



    2)var 聲明的變量相當于給window添加了個屬性,let不會



    3)var 聲明的變量不具有塊級作用域,let具有塊級作用域



    4)var 可以重復聲明,let只能聲明一次



    5)const 用來定義常量,不可以改值



    6)const 定義的常量必須初始化有值,let可以不設置值



    建議:常量名字因為是不可以改動的值,所以常量名建議用大寫,一般用于定義固定不變的值




    藍藍設計建立了UI設計分享群,每天會分享國內外的一些優秀設計,如果有興趣的話,可以進入一起成長學習,請掃碼ben_lanlan,報下信息,會請您入群。歡迎您加入噢~~希望得到建議咨詢、商務合作,也請與我們聯系。

    文章來源:csdn

    分享此文一切功德,皆悉回向給文章原作者及眾讀者.
    免責聲明:藍藍設計尊重原作者,文章的版權歸原作者。如涉及版權問題,請及時與我們取得聯系,我們立即更正或刪除。

    藍藍設計www.lzhte.cn )是一家專注而深入的界面設計公司,為期望卓越的國內外企業提供卓越的UI界面設計、BS界面設計 、 cs界面設計 、 ipad界面設計 、 包裝設計 、 圖標定制 、 用戶體驗 、交互設計、 網站建設 平面設計服務


    日歷

    鏈接

    個人資料

    藍藍設計的小編 http://www.lzhte.cn

    存檔

    主站蜘蛛池模板: 中文字幕在线日亚州9| 呦交小U女精品视频| 亚洲日韩爆乳中文字幕欧美| 久久综合精品不卡一区二区| 日本BBWW高潮BBWR| 一区二区AV| 国产精品午夜福利精品| 青青青国产视频手机| 在线视频精品一区二区三区| ww.国产| 欧美激情一区二区三区在线播放| 加勒比无码专区中文字幕| 在线播放亚洲一区二区三区| 无码专区AAAAAA免费视频| 成人av无码国产在线观看| 亚洲欧美香蕉在线日韩精选| 按摩师玩弄少妇到高潮hd| 一区国产二区亚洲三区另类| 亚洲成AV人不卡无码| 国产在线高清一级毛片| 久青草久青草视频在线观看| 无码成人片在线播放| 精品偷自拍另类在线观看| 图片区偷拍区小说区五月| 免费一级毛片不卡在线播放| 福利一区二区三区视频| 老湿机网站| 亚洲开心婷婷中文字幕| 国产亚洲精品久久久久妲己| 日韩有码精品中文字幕| 无码人妻精品一区二区三| 日韩国产精品中文字幕| 国产欧美日韩综合一区在线播放 | 国产精品久久精品三级| 白丝精品一区二区三区| 亚洲一区波多野结衣二区三区| 亚洲乱码中文字幕久久孕妇黑人| 欧美成人精品福利视频| 欧美日韩在线第一页| 96精品专区国产在线观看高清| 怡红院一区二区三区在线|