首頁 >web前端 >js教程 >js閉包是什麼?對js閉包的理解

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

不言
不言原創
2018-09-01 15:56:552675瀏覽

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閉包_javascript技巧

如何理解js中的閉包

以上是js閉包是什麼?對js閉包的理解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

相關文章

看更多