DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> JavaScript基礎知識 >> 關於JS中的閉包淺談
關於JS中的閉包淺談
編輯:JavaScript基礎知識     

( ⊙o⊙ )!!!這個也太尼瑪官方了撒,作為菜鳥的我根本無法理解它想表達個什麼意思!但是作為一只好奇的菜鳥又很想知道“閉包”到底是個什麼東西!所以最終找到了傳說中的“度娘”幫忙!還算有了一點小小的理解!

個人見解:在函數體內定義另外的方法函數,而這個方法函數被函數以外的變量引用,這時就形成了閉包!

可能這樣的理解也太抽象了,並不是那麼簡單易懂!實例吧:

復制代碼 代碼如下:
<script type="text/javascript">

function A(){
    var S=0;
    function B(){
        alert(++S);
    }
    return B;
}
var C=A();
C();
</script>

上面這一段代碼就創建了一個閉包,因為當函數執行到var C=A();時,表面上看C指向的是A函數,而實際上C所指向的函數是B函數,所以再執行到C()的時候就會輸出2;這樣的話B函數就被A函數以外的變量引用了,根據個人見解,創建了一個閉包!

當我在小小的了解了什麼時候閉包後也順便看了哈閉包的用途,據說閉包的用途主要有兩點:

1、可以讀取函數內部的變量

2、讓這些變量始終保持在內存中

復制代碼 代碼如下:
<script type="text/javascript">

function A(){
 var S=1;
 D=function(){
        S+=1;
    }
 function B(){
  alert(S);
 }
    return B;
}
var C=A();
C(); // 輸出1
D();
C(); // 輸出2

 </script>

上面的代碼中C指向的還是是B函數,C執行了兩次,第一次輸出1,第二次輸出2,這證明了S一直被保存在內存中,並沒有在A函數在被調用後自動清除,這是為什麼呢,原因是因為B函數被賦給了一個全局變量,這導致了B函數一直在內存中,而B函數的執行又需要依賴著A函數,所以A也一直在內存中,不會在調用結束後被回收!(這樣的理解貌似有點不專業)!

表達完畢,請廣大群眾多多指教!

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved