久久精品五月,日韩不卡视频在线观看,国产精品videossex久久发布 ,久久av综合

站長資訊網
最全最豐富的資訊網站

javascript中作用域一般分幾種?js中有沒有塊作用域?

在javascript中,作用域一般分3種,有塊作用域。3種作用域分別為:1、全局作用域,是聲明在所有函數之外的全局變量的作用域;2、局部作用域,是聲明在函數內的局部變量的作用域;3、塊級作用域,是塊級變量聲明語句開始到塊結束之間的區域。

javascript中作用域一般分幾種?js中有沒有塊作用域?

本教程操作環境:windows7系統、javascript1.8.5版、Dell G3電腦。

變量的作用域(scope),指的是變量在腳本代碼中的可讀、寫的有效范圍,也就是腳本代碼中可以使用這個變量的區域。在 ECMAScript6 之前,變量的作用域主要分為全局作用域、局部作用域(也稱函數作用域)兩種;

在 ECMAScript6 及其之后,變量的作用域主要分為全局作用域、局部作用域和塊級作用域這 3 種。

相應作用域的變量分別稱為全局變量、局部變量和塊級變量。

  • 全局變量聲明在所有函數之外;

  • 局部變量是在函數體內聲明的變量或者是函數的命名參數;

  • 塊級變量是在塊中聲明的變量,只在塊中有效。

變量的作用域跟聲明方式有很密切的關系。使用 var 聲明的變量的作用域有全局作用域和函數作用域,沒有塊級作用域;使用 let 和 const 聲明的變量有全局作用域、局部作用域和塊級作用域。

注意:嚴格意義的全局變量都屬于 window 對象的屬性,但 let 和 const 聲明的變量并不屬于 window 對象,所以它們并不是嚴格意義上的全局變量,在此僅僅從它們的作用域這個角度來說它們是全局變量的。

由于 var 支持變量提升,所以 var 變量的全局作用域是對整個頁面的腳本代碼有效;而 let 和 const 不支持變量提升,所以 let 和 const 變量的全局作用域指的是從聲明語句開始到整個頁面的腳本代碼結束之間的整個區域,而聲明語句之前的區域是沒有效的。

同樣,因為 var 支持變量提升,而 let 和 const 不支持變量提升,所以使用 var 聲明的局部變量在整個函數中有效,而使用 let 和 const 聲明的局部變量從聲明語句開始到函數結束之間的區域有效。

需要注意的是,如果局部變量和全局變量同名,則在函數作用域中,局部變量會履蓋全局變量,即在函數體中起作用的是局部變量;在函數體外,全局變量起作用,局部變量無效,此時引用局部變量將出現語法錯誤。

對塊級變量來說,其作用域是塊級變量聲明語句開始到塊結束之間的區域。在塊開始到塊級變量聲明語句之間的區域為“暫時性死區”,在這個區域,塊級變量沒有效。

另外,在非嚴格運行模式中,變量可以不需要聲明,這些沒有聲明的變量,不管在哪里使用都屬于全局變量。通常不建議變量不聲明而直接使用,因為這樣有可能會產生一些不易發現的錯誤。

【例 1】變量的作用域示例。

<!doctype html> <html> <head> <meta charset="utf-8"> <title>變量作用域示例</title> <script>         var v1 = "JavaScript"; //全局變量      let v2 = "JScript"; //全局變量      let v3 = "Script"; //全局變量      scopeTest();    //調用函數      function scopeTest(){          var lv = "aaa"; //局部變量          var v1 = "bbb"; //局部變量          let v2 = "ccc"; //局部變量          if(true){               let lv = "123"; //塊級變量               console.log("塊內輸出的lv = " + lv); //123          }          console.log("函數體內輸出的lv = " + lv); //aaa          console.log("函數體內輸出的v1 = " + v1); //bbb          console.log("函數體內輸出的v2 = " + v2); //ccc          console.log("函數體內輸出的v3 = " + v3); //Script          //v4為全局變量,賦值在后面,因而值為undefined          console.log("函數體內輸出的v4 = " + v4);      }      var v4 = "VBScript"; //全局變量      console.log("函數體外輸出的lv = " + lv); //① 報ReferenceError錯誤      console.log("函數體外輸出的v1 = " + v1); //JavaScript      console.log("函數體外輸出的v2 = " + v2); //JScript      console.log("函數體外輸出的v3 = " + v3); //Script      console.log("函數體外輸出的v3 = " + v4); //VBScript </script> </head> <body> </body> </html>

上述腳本代碼分別聲明了 4 個全局變量、3 個局部變量和 1 個塊級變量。在 scopeTest 函數體外,變量 v1、v2、v3 和 v4 為全局變量;在 scopeTest 函數體內,lv、v2是全局變量;在 if 判斷塊中,lv 是塊級變量。

我們看到,局部變量 v1 和 v2 與全局變量 v1 和 v2 同名,在 scopeTest 函數體內,局部變量 v1 和 v2 有效,因而在函數體這 2 個變量的輸出結果分別為“bbb”和“ccc”;在函數體外,全局變量 v1 和 v2 有效,因而在函數體外,這 2 個變量的輸出結果分別為“JavaScript”和“JScript”。

另外,塊級變量 lv 和局部變量 lv 同名,在 if 判斷塊中,塊級變量 lv 有效,因而在塊中輸出的結果為“123”,而在塊外,局部變量 lv 有效,lv 變量的輸出結果為“aaa”。

另外,全局變量 v3 和 v4 在函數體中沒有被覆蓋,因而輸出的是全局變量的值,所以 v3 在函數體內和體外的輸出結果都為“Script”,而 v4 變量的賦值在函數調用的后面,因而在函數體中的 v4 輸出結果為“undefined”,而在函數體外的輸出是在聲明之后,所以結果為“VBScript”。lv 是局部變量,因而在函數體外訪問會報“ReferenceError”錯誤。

上述代碼在 Chrome 瀏覽器中運行后,打開瀏覽器的控制臺,可以看到圖 1 所示的輸出結果。

javascript中作用域一般分幾種?js中有沒有塊作用域?
圖1:① 處代碼注釋前控制臺輸出結果

圖 1 所示報第 26 行代碼(即示例 1 ① 處注釋的代碼)中的 lv 沒有定義的引用錯誤,這是因為 lv 變量為局部變量,離開函數后無效。將這行代碼注釋后再運行,此時打開瀏覽器控制臺可看到圖 2 所示結果。

javascript中作用域一般分幾種?js中有沒有塊作用域?
圖 2:① 處代碼注釋后控制臺輸出結果

從圖 2 可看到,塊級變量在塊內覆蓋局部變量,局部變量在函數體內覆蓋全局變量,沒有被覆蓋的全局變量在函數體內、外都有效。思考:為什么在函數體內 v4 變量的輸出結果是“undefined”而不會報錯?

贊(0)
分享到: 更多 (0)
?
網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
久久精品五月,日韩不卡视频在线观看,国产精品videossex久久发布 ,久久av综合
国产一区成人| 日韩影院免费视频| 欧美日韩a区| 日本成人在线网站| 91成人精品在线| 欧美午夜网站| 日韩avvvv在线播放| 日韩av中文字幕一区二区| 日韩高清在线不卡| 国产欧美日韩精品高清二区综合区 | 日本综合精品一区| 视频一区日韩精品| 日韩av午夜在线观看| 日韩不卡手机在线v区| 久久wwww| 精品欧美视频| 欧美aa在线视频| 日韩精品1区2区3区| 国产suv精品一区二区四区视频 | 欧美日韩国产亚洲一区| japanese国产精品| 精品美女视频| 日韩一级不卡| 色婷婷久久久| 国产精品白丝av嫩草影院| 亚洲综合精品| 色婷婷精品视频| 国产极品久久久久久久久波多结野 | 国精品一区二区三区| 欧美激情精品| 久久精品国产福利| 亚洲欧美日韩专区| 欧美日韩国产一区二区在线观看| 国产亚洲精品美女久久| 成人在线视频区| 欧美日韩国产精品一区二区亚洲| 亚洲毛片一区| 国产成人精品一区二区三区免费| 国产99久久| 日韩黄色免费网站| 欧美激情网址| 久久国内精品| 国产欧美亚洲精品a| 国产黄色一区| 国产精品一线天粉嫩av| 亚洲视频二区| 亚洲综合不卡| 日韩成人三级| 中文字幕在线高清| 福利在线免费视频| 色在线中文字幕| 色爱av综合网| 欧美色图一区| 亚洲欧美一级| 欧美日韩1区| 国产成人久久| 国产亚洲亚洲| 影音先锋久久精品| 国产精品久久免费视频| 婷婷激情一区| 日本免费新一区视频| 香蕉国产精品| 在线综合亚洲| 欧美激情在线精品一区二区三区| 中文字幕av一区二区三区四区| 亚洲丝袜啪啪| 欧美国产极品| 中文字幕一区久| 欧美日韩一视频区二区| 久久免费视频66| 美日韩精品视频| 成人国产精品一区二区免费麻豆| 日韩精品一级中文字幕精品视频免费观看 | 精品中文字幕一区二区三区四区| 精品一区av| 999国产精品999久久久久久| 精品视频自拍| 免费成人在线视频观看| 日韩精品久久理论片| 国产精品99一区二区三| 亚洲91网站| 免费毛片在线不卡| 国产精品白浆| 日韩国产在线一| 国产在线日韩| 成人台湾亚洲精品一区二区| 欧美日韩四区| 精品一区二区三区免费看| 亚洲精品三级| 在线精品国产亚洲| 色婷婷精品视频| 噜噜噜躁狠狠躁狠狠精品视频| 国产欧美日韩一区二区三区在线| 日本在线视频一区二区| 日韩精品国产欧美| 一区在线免费| 亚洲人成网站在线在线观看| 老司机免费视频一区二区三区| 91精品国产调教在线观看| 精品视频在线你懂得| 欧美日韩一区二区国产 | 久久麻豆精品| 国精品产品一区| 国产精品久久久免费| 五月天久久网站| 国产精品久久久久蜜臀| 精品视频免费| 尹人成人综合网| 日本久久黄色| 日韩欧美不卡| 99久久精品国产亚洲精品| 国产aⅴ精品一区二区三区久久| 亚洲精品无吗| 日本不卡视频在线观看| 尤物精品在线| 91精品精品| 亚洲精品一级二级三级| 亚洲我射av| 欧美国产中文高清| 国产999精品在线观看| 久久成人高清| 久久久久国产| 亚洲神马久久| 日韩二区三区在线观看| 麻豆精品视频在线| 久久久久久自在自线| 色婷婷久久久| 日韩精品一区二区三区免费视频 | 免费视频最近日韩| 亚洲黄页一区| 欧美网站在线| 亚洲欧美日韩一区在线观看| 老牛影视一区二区三区| 久热综合在线亚洲精品| 久久亚洲二区| 亚洲乱码久久| 欧美日韩在线精品一区二区三区激情综合| 日韩一区二区三免费高清在线观看 | 亚洲精品一区二区在线播放∴| 国产日韩综合| 日韩高清不卡在线| 日韩欧美精品综合| 日本欧洲一区二区| 日韩高清在线观看一区二区| 四虎国产精品免费观看| 国产一级久久| 国产精品亚洲综合在线观看| 黑森林国产精品av| 欧美专区一区| 免费成人在线视频观看| 国产伦久视频在线观看| 亚久久调教视频| 激情丁香综合| 国产精品一区二区av日韩在线| 一区二区国产在线观看| 免费在线观看不卡| 国户精品久久久久久久久久久不卡| av资源中文在线| 国产精品久久久网站| 精品黄色一级片| 国模精品一区| 亚洲欧美日韩国产| 国产香蕉精品| 久久狠狠久久| 国产精品啊v在线| 日韩精品电影| 久久国产成人| 国产亚洲一区二区三区啪| 成年男女免费视频网站不卡| 在线亚洲国产精品网站| 国产精品尤物| 午夜欧美在线| 欧美亚洲二区| 综合干狼人综合首页| 日韩专区在线视频| 亚洲午夜在线| 91亚洲国产高清| 久久青青视频| 伊人影院久久| 国产在线不卡| 国产精品视区| 综合激情一区| 国产调教精品| 毛片不卡一区二区| 91综合网人人| 久久亚洲精品中文字幕蜜潮电影| 欧美日韩四区| 日韩黄色av| 日本精品黄色| 日韩亚洲在线| 国产精品毛片久久久| 日韩午夜视频在线| 日韩高清中文字幕一区| 精品视频高潮| 免费视频亚洲| av成人国产| 久久av在线| 日韩成人一级| 国产精品mv在线观看| 国产精品7m凸凹视频分类|