您好,登錄后才能下訂單哦!
一、塊級作用域的說明
在學習JavaScript的變量作用域之前,我們應當明確幾點:
a、JavaScript的變量作用域是基于其特有的作用域鏈的。
b、JavaScript沒有塊級作用域。
c、函數中聲明的變量在整個函數中都有定義。
javascript的變量作用域,與平時使用的類C語言不同,例如C#中的代碼:
static void Main(string[] args) { if(true) { int number=10; } Console.WriteLine(number); }
這段代碼進行編譯,是無法通過的,因為"當前上下文不存在number".
因為這里變量的作用域是由花括號限定的,稱為塊級作用域。
在塊級作用域下,所有的變量都在定義的花括號內,從定義開始到花括號結束這個范圍內可以使用,出了這個范圍就是無法訪問,也就是說
if(true) { int number=10; Console.WriteLine(number); }
這樣可以訪問,因為變量的定義與使用在同一個花括號內。
但是在javascript中沒有塊級作用域的概念。
二、javascript中的作用域
1、函數限定變量作用域
在javascript中,函數里面定義的變量,,可以在函數里面被訪問,但在函數外無法訪問,代碼:
<script type="text/javascript"> var num=function() { var number=10; }; try{ alert(number); }catch(e) { alert(e); } </script>
代碼運行時,會拋出一個異常,變量number沒有定義,是因為定義在函數中的變量無法再函數外使用,在函數內可以任意使用,即使在賦值之前:
<script type="text/javascript"> var num=function(){ alert(number); var number=10; alert(number); }; try{ num(); }catch(e){ alert(e); } </script>
這段代碼運行后,不會拋出錯誤,彈出兩次,分別是undefined和10
2.子域訪問父域
函數可以限定變量的作用域,那么在函數中的函數就為該作用域的子域,在子域中的代碼可以訪問到父域中的變量,代碼如下:
<script type="text/javascript"> var func=function(){ var number=10; var sub_func=function(){ alert(num); }; sub_func(); }; func(); </script>
這段代碼執行得到的結果是10,但是在子域中訪問父域的代碼也是有條件的
<script type="text/javascript"> var func=function(){ var number=10; var sub_func=function(){ var num=20; alert(num); }; sub_func(); }; func(); </script>
這段代碼比前面多了一個"var num=20;",這句代碼在子域中,那么子域訪問父域的情況就發生了變化,這段代碼打印的結果是20,此時子域訪問的num是子域中的變量,而不是父域中的。由此可見訪問有一定規則可言,在javascript中使用變量,javascript解釋器首先在當前作用域中搜索是否有該變量的定義,如果有,就是用這個變量,如果沒有就到父域中尋找變量,依次類推,直到最頂級作用域,仍然沒有找到就拋出異常"變量未定義",代碼如下:
<script type="text/javascript"> (function (){ var num=10; (function (){ var num=20; (function(){ alert(num); })(); })(); })(); </script>
這段代碼執行后打印出20,如果將"var num=20
"取掉,那么打印的就是10.同樣去掉"var num=10
",那么就會出現未定義的錯誤。
下面介紹下JS作用域與塊級作用域
作用域永遠都是任何一門編程語言中的重中之重,因為它控制著變量與參數的可見性與生命周期。講到這里,首先理解兩個概念:塊級作用域與函數作用域。
什么是塊級作用域呢?
任何一對花括號({和})中的語句集都屬于一個塊,在這之中定義的所有變量在代碼塊外都是不可見的,我們稱之為塊級作用域。
函數作用域就好理解了(*^__^*) ,定義在函數中的參數和變量在函數外部是不可見的。
大多數類C語言都擁有塊級作用域,JS卻沒有。請看下文demo:
//C語言 #include <stdio.h> void main() { int i=2; i--; if(i) { int j=3; } printf("%d/n",j); }
運行這段代碼,會出現“use an undefined variable:j”的錯誤。可以看到,C語言擁有塊級作用域,因為j是在if的語句塊中定義的,因此,它在塊外是無法訪問的。
而JS是如何表現的呢,再看另一個demo:
functin test(){ for(var i=0;i<3;i++){ } alert(i); } test();
運行這段代碼,彈出"3",可見,在塊外,塊中定義的變量i仍然是可以訪問的。也就是說,JS并不支持塊級作用域,它只支持函數作用域,而且在一個函數中的任何位置定義的變量在該函數中的任何地方都是可見的。
那么我們該如何使JS擁有塊級作用域呢?是否還記得,在一個函數中定義的變量,當這個函數調用完后,變量會被銷毀,我們是否可以用這個特性來模擬出JS的塊級作用域呢?看下面這個DEMO:
function test(){ (function (){ for(var i=0;i<4;i++){ } })(); alert(i); } test();
這時候再次運行,會彈出"i"未定義的錯誤,哈哈,實現了吧~~~這里,我們把for語句塊放到了一個閉包之中,然后調用這個函數,當函數調用完畢,變量i自動銷毀,因此,我們在塊外便無法訪問了。
JS的閉包特性is the most important feature((*^__^*) 大家懂的)。在JS中,為了防止命名沖突,我們應該盡量避免使用全局變量和全局函數。那么,該如何避免呢?不錯,正如上文demo所示,我們可以把要定義的所有內容放入到一個
(function (){ //內容 })();
總結
以上所述是小編給大家介紹的Javascript中的作用域及塊級作用域,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對億速云網站的支持!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。