<em id="09ttv"></em>
    <sup id="09ttv"><pre id="09ttv"></pre></sup>
    <dd id="09ttv"></dd>

        • 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

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

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


          日歷

          鏈接

          個人資料

          藍藍設計的小編 http://m.sdgs6788.com

          存檔

          亚洲国产精品人久久| 国产精品成人无码久久久久久| 人妻系列无码专区久久五月天| 久久人人青草97香蕉| 久久精品国产亚洲av瑜伽| 久久噜噜久久久精品66| 狠狠色综合网站久久久久久久高清| 欧美午夜精品久久久久免费视| 久久国产精品国产自线拍免费 | 精品久久久无码人妻中文字幕| 色婷婷久久综合中文久久蜜桃av| 久久99精品免费一区二区| 久久久久亚洲AV成人网人人网站 | 久久精品国产网红主播| 91精品婷婷国产综合久久| 久久久久久久精品成人热色戒| 日本道色综合久久影院| 亚洲AV无码一区东京热久久| 久久精品这里只有精99品| 久久99热只有频精品8| 久久久久久久久波多野高潮| 无码任你躁久久久久久| 国产无套内射久久久国产| 精品免费tv久久久久久久| 日日躁夜夜躁狠狠久久AV| 久久亚洲国产精品五月天婷| 狠狠色丁香久久综合五月| 人妻精品久久无码区 | 中文字幕久久欲求不满| 国产精品一久久香蕉国产线看观看 | 久久久精品人妻一区二区三区蜜桃 | 久久久网中文字幕| 久久久免费观成人影院| 久久99精品国产麻豆蜜芽| 国产日韩久久久精品影院首页| 69SEX久久精品国产麻豆| 9久久9久久精品| 97久久香蕉国产线看观看| 99久久精品午夜一区二区 | 亚洲精品WWW久久久久久| 天天综合久久一二三区|