成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

你所知道的JS變量作用域

開發 前端
變量的作用域,指的是變量在腳本代碼中的可讀、可寫的有效范圍,也就是腳本代碼中可以使用這個變量的區域。

[[352996]]

本文轉載自微信公眾號「前端歷劫之路」,作者maomin9761。轉載本文請聯系前端歷劫之路公眾號。  

變量的作用域,指的是變量在腳本代碼中的可讀、可寫的有效范圍,也就是腳本代碼中可以使用這個變量的區域。在ES6之前,變量的作用域主要分為全局作用域、局部作用域(也稱函數作用域)兩種;在ES6及其之后,變量的作用域主要分為全局作用域、局部作用域、塊級作用域這3種。相應作用域變量分別稱為全局變量、局部變量、塊級變量。全局變量聲明在所有函數之外;局部變量是在函數體內聲明的變量或者是函數的命名參數;塊級變量是在塊中聲明的變量,只在塊中有效。

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

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

由于var支持變量提升,所以var變量的全局作用域是對整個頁面的腳本代碼有效;而let和const不支持變量提升,所以let和const變量的全局作用域指的是從聲明語句開始到整個頁面的腳本代碼結束之間的整個區域,而聲明語句之前的區域是沒有效的。同樣,因為var支持變量提升,而let和const不支持變量提升,所以使用var聲明的局部變量是在整個函數有效,而使用let和const聲明的局部變量從聲明語句開始到函數結束之間的區域有效。需要注意的是,如果局部變量和全局變量同名,則在函數作用域中,局部變量會覆蓋全局變量,即在函數體中起作用的是局部變量;在函數體外,全局變量起作用,局部變量無效,此時引用局部變量將出現語法錯誤。在塊開始到塊級變量聲明語句之間區域為暫時性死區,在這個區域,塊級變量沒有效。

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

  1. <!DOCTYPE html> 
  2. <html> 
  3. <head> 
  4.  <title></title> 
  5. </head> 
  6. <body> 
  7. <script> 
  8.    var v1 = "JavaScript"; // 全局變量 
  9.    let v2 = "JScript"; // 全局變量 
  10.    let v3 = "Script"; // 全局變量 
  11.     
  12.    scopeTest(); // 調用函數 
  13.    function scopeTest(){ 
  14.     var lv = "aaa";//局部變量 
  15.         var v1 = "bbb";//局部變量 
  16.         let v2 = "ccc";//局部變量 
  17.         if(true){ 
  18.             let lv = "123"
  19.             console.log("塊級輸出的lv= " + lv); // 123 
  20.         } 
  21.          
  22.         console.log("函數體內輸出的lv = " +lv); //aaa 
  23.         console.log("函數體內輸出的v1 = " +v1); //bbb 
  24.         console.log("函數體內輸出的v2 = " +v2); //ccc 
  25.         console.log("函數體內輸出的v3 = " +v3); //Script 
  26.         console.log("函數體內輸出的v4 = " +v4); // undefined, v4為全局變量,賦值在后面,var存在變量提升,因而值為undefined 
  27.    } 
  28.    var v4 = "VB"; //全局變量 
  29.    console.log("函數體外輸出的lv = " +lv); // 報ReferenceError錯誤 
  30.    console.log("函數體內輸出的v1 = " +v1); //JavaScript 
  31.    console.log("函數體內輸出的v2 = " +v2); //JScript 
  32.    console.log("函數體內輸出的v3 = " +v3); //Script 
  33.    console.log("函數體內輸出的v4 = " +v4); // VB 
  34. </script> 
  35. </body> 
  36. </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,而在函數體外的輸出是在聲明之后,所以結果為VB。lv是局部變量,因而在函數體外訪問會報ReferenceError錯誤。

 

總結:塊級變量在塊內覆蓋局部變量,局部變量在函數體內覆蓋全局變量,沒有被覆蓋的全局變量在函數體內、外都有效。

 

責任編輯:武曉燕 來源: 前端歷劫之路
相關推薦

2021-07-05 08:43:46

Spring Beanscope作用域

2023-09-05 08:23:56

SpringScope方法

2023-09-27 08:33:16

作用域CSS

2013-04-25 09:12:36

2015-08-18 13:42:42

js作用域鏈變量

2017-01-15 11:38:24

2017-01-15 13:37:05

2020-04-02 10:36:43

JS代碼函數

2016-12-26 16:58:37

2011-04-18 09:31:35

JavaScript

2021-03-09 08:35:51

JSS作用域前端

2016-09-19 13:52:26

Javascript跨域前端

2019-06-03 10:14:07

API網關微服務

2013-09-05 10:07:34

javaScript變量

2010-01-07 16:16:03

VB.NET變量作用域

2021-06-02 07:02:42

js作用域函數

2016-12-19 11:10:32

JavaScript變量作用域

2009-06-01 11:16:48

PHP網站開發變量作用域

2018-11-28 11:20:09

區塊鏈中本聰分布式

2022-03-10 08:25:27

JavaScrip變量作用域
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 一级黄色影片在线观看 | 日日碰狠狠躁久久躁96avv | aaa一区| 国外成人在线视频网站 | 国产一区二区视频在线 | 欧美日韩成人在线观看 | 6996成人影院网在线播放 | 99精品久久久久 | 五月综合色啪 | 99re6在线视频精品免费 | 亚洲视频在线观看免费 | 国产一区免费 | 日韩亚洲欧美综合 | 亚洲成人免费视频 | 欧美成人免费电影 | 中文字幕 国产精品 | 国产精品成人一区二区三区 | 中文字幕在线一区 | 国产午夜精品久久久久免费视高清 | 成人在线免费观看 | 性色av网站 | 成人影 | 国产一区在线免费 | 久久精品国产精品青草 | 在线视频亚洲 | 亚洲精品久久久久久一区二区 | 精品久久国产老人久久综合 | 成人网视频 | 青青操91 | 婷婷综合色 | 免费观看www | 日韩国产在线 | 国产高清视频一区二区 | 欧美片网站免费 | 999免费视频 | 成人免费大片黄在线播放 | 国产精品久久久久久久久久免费看 | 91xxx在线观看 | 成人免费网站 | 久久不卡 | 欧美一级免费看 |