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

        javascript中作用域是什么

        在javascript中,作用域是變量(對象、函數)的可訪問范圍,是變量在腳本代碼中的可讀、寫的有效范圍;作用域可以控制變量的可見性和生命周期。

        javascript中作用域是什么

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

        幾乎所有的語言都有作用域的概念,簡單的說,作用域(scope)就是變量的可訪問范圍,即作用域控制變量的可見性和生命周期。

        在 JavaScript 中, 對象和函數同樣也是變量。

        在 ECMAScript6 之前,變量的作用域主要分為全局作用域、局部作用域(也稱函數作用域)兩種;在 ECMAScript6 及其之后,變量的作用域主要分為全局作用域、局部作用域和塊級作用域這 3 種。

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

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

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

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

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

        <!DOCTYPE html> <html> 	<head> 		<meta charset="utf-8"> 	</head> 	<body> 		<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> 	</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 瀏覽器中運行后,打開瀏覽器的控制臺,可以看到下圖所示的輸出結果。

        javascript中作用域是什么

        28行代碼報錯的原因:

        lv 變量為局部變量,離開函數后無效。將這行代碼注釋后再運行,此時打開瀏覽器控制臺可看到:

        javascript中作用域是什么

        贊(0)
        分享到: 更多 (0)
        網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
        主站蜘蛛池模板: 国产成人精品无码播放| 欧美黑人巨大videos精品| 国产精品国产三级在线高清观看| 日产精品99久久久久久| 国产亚洲精品免费视频播放| 国产精品欧美亚洲韩国日本不卡| 亚洲精品线路一在线观看| 94久久国产乱子伦精品免费 | 久久se精品一区精品二区| 亚洲精品成人无限看| 欧美精品三区| 精品精品国产欧美在线小说区 | 日本午夜精品一区二区三区电影| 国产亚洲精品无码拍拍拍色欲| 亚洲欧美日韩精品| 国产香蕉精品视频在| 国产精品视频永久免费播放| 亚洲动漫精品无码av天堂| 日韩精品电影一区亚洲| 精品成人一区二区三区四区| 91亚洲精品自在在线观看| 日韩精品在线一区二区| 精品国产一区二区三区久久| 99视频精品全部在线观看| 亚洲AV无码久久精品狠狠爱浪潮| 亚洲一日韩欧美中文字幕欧美日韩在线精品一区二 | 亚洲国产精品自在在线观看| 91精品在线播放| 91精品国产高清久久久久久io | 亚洲精品乱码久久久久66| 亚洲精品制服丝袜四区| 野狼第一精品社区| 久久精品国产影库免费看 | 国产日韩久久久精品影院首页| 999精品色在线播放| 6080亚洲精品午夜福利| 亚洲综合精品香蕉久久网97| 成人国产精品日本在线观看| 国产精品欧美久久久久无广告| 囯产精品一区二区三区线| 国产精品久久久99|