国产精品美女久久久浪潮AV,国产精品三级一二三区,久久精品国产一区二区小说 ,依依成人影视国产精品,全部无卡免费的毛片在线看,日本一区二区三深夜不卡,国产精品女同一区二区久久,国产精品夜色一区二区三区

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


        日歷

        鏈接

        個人資料

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

        存檔

        主站蜘蛛池模板: 国产精品中文色婷婷综合蜜桃视频 | 河东区| 亚洲精品国产美女久久久99| av无码精品一区二区三区| 国产女人好紧好爽| 久热国产vs视频在线观看| 色综合久久精品亚洲国产| 九九99亚洲精品久久久久| 丰满人妻熟妇乱又仑精品| 国产vivodeshd精品| 亚洲av无码乱码在线观看牲色| 亚洲人成电影在线天堂色| 国产精品久久..4399| ........天堂网www在线| 国产精品天干天干综合网| 成人毛片无码一区二区三区| 久久久久久久无码高潮| 麻豆国产97在线 | 欧美| 豆国产96在线 | 亚洲| 草草地址线路①屁屁影院成人| 色婷婷综合激情综在线播放| 欧美24videossex性欧美| 公粗挺进了我的密道在线播放| 国产vivodeshd精品| 无码熟妇人妻av在线网站| 欧美疯狂xxxxbbbb喷潮| 爱情岛论坛亚洲永久入口口| yyyy11111少妇无码影院| 无码人妻精品一区二区三区夜夜嗨 | 在线观看肉片av网站免费 | 彰化县| 忍着娇喘在公面前被夜袭| 国产真实强被迫伦姧女在线观看 | 国产午夜精品久久久久免费视| 调教女m屁股撅虐调教| 泊头市| 色婷婷亚洲精品综合影院| 久久露脸国产精品| 久久国产精品99夜夜嗨| 一个人看的视频免费高清| 人妻少妇被猛烈进入中文字幕|