国产精品爱久久久久久久小说,女人扒开腿让男人桶到爽 ,亚洲欧美国产双大乳头,国产成人精品综合久久久久,国产精品制服丝袜无码,免费无码精品黄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.dzxscac.cn )是一家專注而深入的界面設計公司,為期望卓越的國內外企業提供卓越的UI界面設計、BS界面設計 、 cs界面設計 、 ipad界面設計 、 包裝設計 、 圖標定制 、 用戶體驗 、交互設計、 網站建設 平面設計服務


            日歷

            鏈接

            個人資料

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

            存檔

            主站蜘蛛池模板: 自拍av在线| 欧美国产伦久久久久久久| 久久久青青草| 97精品国产一区二区三区| 狠狠色丁香婷婷久久综合蜜芽| 91视频看看| 91亚洲国产| 日本波多野结衣在线| 少妇性饥渴无码a区免费| 一边摸一边抽搐一进一出视频| 久久爱资源网| 欧美变态另类刺激| 深夜福利网站| 激情黄色av| 亚洲乱码国产乱码精品精大量| 在线看片免费人成视频网| xiuxiuavnet| 国产综合久久久久鬼色| 国产成人亚洲综合无码18禁h| 日韩欧美高清在线| 一区二区三区精品不卡| 亚欧免费无码aⅴ在线观看蜜桃| 伊人天堂网| 人人草人人射| 3d动漫精品啪啪一区二区下载| 同性女女黄h片在线播放| 91精品国产视频| 日韩成人性视频在线观看| 久久久久国色a∨免费看| 人妻丰满熟妇av无码久久洗澡| 男女搞鸡网站| 久青草国产在视频在线观看| 人妻丝袜av先锋影音先| av在线电影网站| 国产亚洲精品在av| 在线岛国片免费无码av| 亚洲天堂视频在线观看| 亚洲深夜视频| 免费大片av手机看片高清| 国产一区精选播放022| 国产精品久久久久久久久借妻|