99久久精品国产片-99久久精品国产免费-99久久精品国产麻豆-99久久精品国产国产毛片-99久久精品国产高清一区二区-99久久精品费精品国产一区二区

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


日歷

鏈接

個人資料

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

存檔

国产激情视频在线观看| 毛片高清| 美女被草网站| 韩国三级视频在线观看| 成人免费观看视频| 国产成人精品影视| 美国一区二区三区| 亚洲爆爽| 天天做人人爱夜夜爽2020| 国产激情一区二区三区| 久久成人亚洲| 亚洲www美色| 亚洲第一色在线| 九九久久99| 欧美另类videosbestsex久久| 成人免费观看的视频黄页| 成人免费观看视频| 精品国产一区二区三区免费| 精品国产三级a| 二级特黄绝大片免费视频大片| 91麻豆精品国产自产在线观看一区 | 午夜家庭影院| 国产视频一区二区在线播放| 青草国产在线| 国产精品12| 国产不卡精品一区二区三区| 国产国语对白一级毛片| 国产91素人搭讪系列天堂| 欧美激情伊人| 日韩中文字幕在线亚洲一区| 成人高清护士在线播放| 国产福利免费观看| 成人在免费观看视频国产| 日本伦理黄色大片在线观看网站| 国产视频一区二区三区四区| 精品视频一区二区三区免费| 九九热精品免费观看| 成人免费一级纶理片| 精品久久久久久免费影院| 国产成人欧美一区二区三区的| 国产精品自拍一区| 国产国语对白一级毛片| 日韩在线观看免费完整版视频| 成人免费观看男女羞羞视频| 欧美a级v片不卡在线观看| 99久久精品国产国产毛片| 四虎影视库国产精品一区| 你懂的福利视频| 亚欧视频在线| 欧美激情一区二区三区视频高清| 麻豆系列国产剧在线观看| 成人a级高清视频在线观看| 色综合久久天天综合观看| 欧美激情影院| 久久精品免视看国产明星| 国产视频一区二区在线播放| 尤物视频网站在线| 免费一级片网站| 日本特黄特黄aaaaa大片| 麻豆系列 在线视频| 精品视频在线看 | 台湾美女古装一级毛片| 韩国三级视频在线观看| 欧美日本国产| 日韩av东京社区男人的天堂| 国产一区精品| 国产视频一区二区三区四区| 中文字幕Aⅴ资源网| 欧美日本韩国| 可以免费在线看黄的网站| 亚欧乱色一区二区三区| 成人影院久久久久久影院| 97视频免费在线观看| 91麻豆精品国产综合久久久| 欧美电影免费| 日韩在线观看网站| 免费国产在线观看| 国产伦久视频免费观看视频| 免费国产在线观看| 欧美另类videosbestsex久久| 精品国产香蕉在线播出| 国产视频在线免费观看| 91麻豆国产福利精品| 国产精品自拍亚洲| 国产麻豆精品高清在线播放| 国产视频在线免费观看| 国产美女在线一区二区三区| 久久精品大片| 国产网站免费在线观看| 国产福利免费观看| 欧美a级片视频| 日本在线www| 免费一级生活片| 久久99中文字幕| 国产伦久视频免费观看视频| 亚洲wwwwww| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 国产网站在线| 国产网站麻豆精品视频| 日韩在线观看网站| 国产精品1024永久免费视频| 欧美大片aaaa一级毛片| 日韩在线观看视频免费| 99色吧| 毛片高清| 黄色短视屏| 毛片高清| 日本免费看视频| 久久国产精品只做精品| 欧美激情一区二区三区在线| 日本特黄特色aaa大片免费| 人人干人人插| 天天做人人爱夜夜爽2020| 欧美a级片视频| 国产极品精频在线观看| 日韩专区第一页| 国产精品1024永久免费视频 | 可以在线看黄的网站| 精品国产三级a| 91麻豆tv| 精品毛片视频| 国产一区二区精品| 91麻豆精品国产综合久久久| 黄色福利片| 可以在线看黄的网站| 亚洲 欧美 成人日韩| 黄色免费三级| 国产91丝袜在线播放0| 国产欧美精品| 美女免费精品视频在线观看| 国产极品精频在线观看| 九九九国产| 精品国产亚洲一区二区三区| 青青久久精品国产免费看| 久久国产影院| 久久久久久久久综合影视网| 亚欧成人毛片一区二区三区四区| 久久精品大片| 麻豆网站在线看| 99久久网站| 国产伦精品一区三区视频| 国产成人欧美一区二区三区的| 欧美a级大片| 欧美a免费| 久久99爰这里有精品国产| 精品国产一区二区三区国产馆| 尤物视频网站在线| 成人免费观看男女羞羞视频| 99热热久久| 黄视频网站在线看| 亚洲 国产精品 日韩| 黄色短视屏| 中文字幕一区二区三区 精品| 日本特黄特色aaa大片免费| 免费国产在线视频| 国产成人啪精品| 免费的黄色小视频| 九九免费高清在线观看视频| 中文字幕Aⅴ资源网| 国产伦精品一区三区视频| 你懂的福利视频| 日本特黄特色aa大片免费| 欧美a级大片| 四虎影视精品永久免费网站| 亚洲天堂免费| 91麻豆精品国产综合久久久| 天天做人人爱夜夜爽2020| 久久精品免视看国产成人2021| 天天做人人爱夜夜爽2020| 国产综合91天堂亚洲国产| 999久久狠狠免费精品| 国产91视频网| 亚洲第一页乱| 成人免费观看视频| 日韩一级黄色| 亚洲 欧美 91| 国产极品精频在线观看| 亚洲精品影院| 日本在线不卡视频| 国产精品1024永久免费视频| 精品国产香蕉在线播出 | 天天做日日爱夜夜爽| 免费国产在线观看| 国产一区二区福利久久| 午夜在线影院| 精品国产亚洲一区二区三区| 一本伊大人香蕉高清在线观看| 欧美激情一区二区三区在线播放| 精品国产亚洲人成在线| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 精品国产一区二区三区久久久蜜臀 | 国产成人精品影视| 九九精品影院| 国产网站麻豆精品视频| 国产伦精品一区三区视频| 美女免费毛片| 韩国三级视频在线观看| 欧美a免费| 国产不卡在线播放| 欧美日本国产|