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視頻教程欄目去學習一下。