JavaScript之再談回調與閉包

  前些陣子寫了幾篇關於回調和閉包的博文,感受本身都是似懂非懂,最近在項目中又碰到了相似的狀況,故在此我們來重彈js中的回調與閉包。閉包

  先說說回調:異步

  百度百科:函數

    回調函數就是一個經過函數指針調用的函數。若是你把函數的指針(地址)做爲參數傳遞給另外一個函數,當這個指針被用爲調用它所指向的函數時,咱們就說這是回調函數。回調函數不是由該函數的實現方直接調用,而是在特定的事件或條件發生時由另外的一方調用的,用於對該事件條件進行響應。spa

    在JavaScript中:回調函數的具體定義爲:  函數A做爲參數(函數引用)傳遞到另外一個函數B中,而且這個函數B執行函數A。咱們就說函數A叫作回調函數。若是沒有名稱(函數表達式),就叫作匿名回調函數。指針

    在js中,AJAX的異步加載時用到了回調函數的,但其實回調不只僅是用在異步中,同步操做也可使用:code

同步的場景: 即在每一個函數執行完成後調用另外一個函數,下面列出網上的一些代碼以做例子:對象

var func1=function(callback){
    //do something.
    (callback && typeof(callback) === "function") && callback(); //檢測函數存在且是一個函數而後再調用
}

func1(func2);
    var func2=function(){
}

異步的狀況的或就不用多說了,咱們在AJAX中都是用的不要不要的了。blog

何時使用回調函數呢,這裏列出一些前人總結的經驗:事件

image

 

-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ip

 

閉包(彷佛是談JavaScript漏不掉的問題):

  什麼是閉包?仍是那句話:  首先,他是一個函數,其次,他能訪問包含他的外部函數的變量,粗糙點理解,就是:定義在一個函數內部的函數,可是呢,這個裏面的函數他訪問了他外面的那個函數的變量。這對於外面函數來講,就造成了閉包,

官方解釋:


來源:知乎
Javascript 中,每一個函數都有一個與之相關聯的做用域鏈。每次調用 JavaScript 函數的時候,都會爲之建立一個新的對象用來保存局部變量,並把這個對象添加至做用域鏈中。當函數返回時,再將這個對象刪除,此對象會被當作垃圾回收。但若是這個函數定義了嵌套的函數,並將它存儲在某處的屬性裏,就意味着有了一個外部引用指向這個嵌套的函數。它就不會被看成垃圾回收,它所指向的變量綁定對象一樣不會被回收

 

來源:JavaScript祕密花園
閉包是 JavaScript 一個很是重要的特性,這意味着當前做用域老是可以訪問外部做用域中的變量。 由於 函數 是 JavaScript 中惟一擁有自身做用域的結構,所以閉包的建立依賴於函數。

 

 

 

舉個栗子:

function foo(x) {
    var tmp = 3;
    return function (y) {
        alert(x + y + (++tmp));
    }
}
var bar = foo(2); // bar 如今是一個閉包
bar(10);      //16

  

此時,在foo函數中已經造成了一個閉包,這就意味着,只要bar函不死,垃圾回收機制就不敢去動foo函數,而此時,咱們的bar函數所指向的那個匿名函數就能夠一直去訪問那個tmp和x,且,注意了!注意了!:::每次調用,都會獲得上一次被自增了之後的tmp

bar(10); //16 第一次調用

bar(10);  //17   第二次調用

同時,咱們強調:

           外部函數不是必需的。經過訪問外部變量,一個閉包能夠維持(keep alive)這些變量。在內部函數和外部函數的例子中,外部函數能夠建立局部變量,而且最終退出;可是,若是任何一個或多個內部函數在它退出後卻沒有退出,那麼內部函數就維持了外部函數的局部數據。

一個典型的例子就是全局變量的使用。 

    記得曾經有人說過:

In computer science, a closure is a function together with a referencing environment for the nonlocal names (free variables) of that function.

      仁者見仁智者見智啦!!!

在JAVA中,咱們知道他有一個叫數據隱藏的特性:  那麼,JavaScript中的閉包,或許爲咱們敞開了大門:

  來看看網上的例子:

image

似曾相識!!!有木有:

 

OK  THAT’S   IT!!!

相關文章
相關標籤/搜索