• <abbr id="chdyf"></abbr>
    <ruby id="chdyf"><acronym id="chdyf"><meter id="chdyf"></meter></acronym></ruby>
    <bdo id="chdyf"></bdo>
    <dfn id="chdyf"><menu id="chdyf"></menu></dfn>
    1. <menuitem id="chdyf"></menuitem><strong id="chdyf"><menu id="chdyf"></menu></strong>

      <rt id="chdyf"><menu id="chdyf"></menu></rt>
      成人小说一区二区三区,伊人精品成人久久综合全集观看,久久HEZYO色综合,中文字幕精品人妻熟女,影音先锋成人网站,我要看免费一级毛片,中国女人做爰A片,中文字幕av久久爽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.wtxcl.cn )是一家專注而深入的界面設計公司,為期望卓越的國內外企業提供卓越的UI界面設計、BS界面設計 、 cs界面設計 、 ipad界面設計 、 包裝設計 、 圖標定制 、 用戶體驗 、交互設計、 網站建設 平面設計服務


      日歷

      鏈接

      個人資料

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

      存檔

      主站蜘蛛池模板: av在线观看免费网站| 一级特黄毛片免费观看| 99视频精品3| 3P在线| 综合av一区| 中文字幕亚洲在线观看| 日韩影片一区二区三区| 最新永久免费AV网站| 国产亚洲福利精品一区二区| 黄色激情网站| 亚洲第1色电影。| 和硕县| 亚洲精品爆乳一区二区H| 爆菊熟女人妻| 国产主播第一页| 泰宁县| 久久亚洲色WWW成人男男| 91精品人人妻人人澡人人爽人人精东影业 | 黑人玩弄漂亮少妇高潮大叫| 亚洲激情偷拍| 福利导航在线| 免费国产1区2区3区4区| 国产探花AV在线日韩精品| 人妻精品视频| 亚洲国产第六| 99久久伊人精品综合观看| 久久久久久久久久8888| 沂水县| 伊人久久大香线蕉av色| 日韩人妻丰满无码区A片| 四季av一区二区| 视频日本一区二区三区| 福利姬Jk丝袜-91Porn| 超碰人人澡| 亚洲AV午夜成人影院老师机影院| 中文字幕国产av| 欧美日韩手机在线视频| 成人超碰| 久久伊人天堂视频网| 91人人妻| 97国产视频|