js閉包是什嗎?對js閉包的理解

來源:互聯網
上載者:User
js中的閉包是什嗎?對於初次接觸到閉包這個概念的朋友們,我相信很多的朋友都會有點不太理解,接下來的這篇文章將給大家來說一說 js閉包該如何理解

閉包(closure)是js中的一個痛點,也是它的特色,很多進階應用程式都要依靠閉包來實現。所以我們先來看一下js閉包的概念。

閉包是什嗎?

根據官方的解釋是:所謂閉包,指的是一個擁有許多變數和綁定了這些變數的環境的運算式(通常是一個函數),因而這些變數也是該運算式的一部分。

單看這一概念,我相信很多的朋友都會感覺難以理解,畢竟這種說法實在是太過於“官方”了,所以,下面我們就來說一說對於js閉包的理解方法。讓你可以更明確的去理解js閉包是什麼。

js閉包的理解

我們先來看一個例子:

def foo() {    var a = 1;    def bar() {        a = a + 1;        alert(a);    }    return bar;}var closure = foo();  // 這個時候返回的是 bar() 這個函數外加其包上的變數 a;var closure2 = foo(); // 這裡同樣產生了另外一個閉包(執行個體)closure(); // 2closure2(); // 2 , 綁定了另外一份變數 aclosure(); // 3

從這個例子我們可以看出:

對於常規的 foo() 方法來說, 在其內部的變數 a 的存在應該在 foo() 方法執行完畢以後就消失了, 但是 foo() 方法返回了一個新的方bar(), 而這個方法卻訪問到了 foo() 方法的變數 a (JavaScript 通過 Scope Chain 訪問到父級屬性), 而方法 bar() 的存在延長了變數 a 的存在時間, 類似與將變數 a 關閉在了自己的範圍範圍內一樣, 只要方法 bar() 沒有失效, 那麼變數 a 則會一直伴隨著方法 bar() 存在, 而變數 a 與方法 bar() 的這樣存在形式被稱為閉包。

從上述例子中,我們可否重新總結一下對js閉包的理解呢?

閉包就是由函數創造的一個詞法範圍,裡面建立的變數被引用後,可以在這個詞法環境之外自由使用。

閉包通常用來建立內部變數,使得這些變數不能被外部隨意修改,同時又可以通過指定的函數介面來操作。

好了,現在對js的閉包是否有了更清晰的理解,如果還是不理解的話,可以去php中文網中的javascript視頻教程欄目去學習一下。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.