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(); // 2 closure2(); // 2 , 绑定了另外一份变量 a closure(); // 3
從這個例子我們可以看出:
#對於常規的foo() 方法來說, 在其內部的變數a 的存在應該在foo() 方法執行完畢以後就消失了, 但是foo() 方法返回了一個新的方bar(), 而這個方法卻訪問了foo() 方法的變數a (JavaScript 透過Scope Chain 存取到父級屬性), 而方法bar() 的存在延長了變數a 的存在時間, 類似與將變數a 關閉在了自己的作用域範圍內一樣, 只要方法bar() 沒有失效, 那麼變數a 則會一直伴隨著方法bar() 存在, 而變數a 與方法bar() 的這樣存在形式被稱為閉包。
從上述例子中,我們可否重新總結一下對js閉包的理解呢?
閉包就是由函數創造的詞法作用域,裡面所建立的變數被引用後,可以在這個詞法環境之外自由使用。
閉包通常用來建立內部變量,使得這些變數不能被外部隨意修改,同時又可以透過指定的函數介面來操作。
好了,現在對js的閉包是否有了更清晰的理解,如果還是不理解的話,可以去php中文網中的javascript視頻教程欄目去學習一下。
相關推薦:
以上是js閉包是什麼?對js閉包的理解的詳細內容。更多資訊請關注PHP中文網其他相關文章!