1. 程式人生 > 程式設計 >JavaScript閉包closure詳述

JavaScript閉包closure詳述

目錄
  • 一、什麼是閉包
  • 二、 閉包的作用

前言:

部分,閉包是很重要的東西,所以我們今天就閉包的相關知識做一總結。首先,在瞭解閉包前,我們先要知道作用域的相關知識,前面 作用域相關博文www.cppcns.com有解釋,這裡不在贅述。接下來我們來看一下什麼是閉包?

一、什麼是閉包

閉包(closure)指有權訪問另一個函式作用域中變數的函式。 ----- Script 高階程式設計

簡單理解閉包就是一個函式,他的特點是:一個作用域可以訪問另外一個函式內部的區域性變數。

舉個簡單的例子:

比如說我們現在有一個函式,在他的內部我們定義了一個區域性變數,如果別的作用域可以訪問這個區域性變數,就產生了閉包。所以我們在該函式內部再定義另一個函式,看看裡面的函式作用域是否可以訪問外函式中的區域性變數。

 function f1(){
            var num = 10;
            function f2(){
                console.log(num);
            }
            f2();
        }
        f1();

列印的結果為:

在這裡插入圖片描述

可以發現成功將值打印出來,所以就產生了閉包。
但是有的讀者可能就有疑問:f2函式本身就在f1函式的內部,它本來就可以使用父函式的變數。那我們再在f1函式的外部的作用域訪問該變數,看看結果又是如何。

我們將f2函式的呼叫改為f1函式的返回值,然後在函式外面呼叫f1函式,如下:

 function f1(){
            var num = 10;
            function f2(){
                console.log(num);
            }
           return f2()
        }
        var f = f1();
        f();

此時,就相當於f1外部的作用域訪問其內部函式的變數。列印結果為:

在這裡插入圖片描述

可以發現,這裡也可以使用其內部的區域性變數,閉包產生。

所以可以得出結論:

閉包: 一個作用域可以訪問另外一個函式內部的區域性變數。

二、 閉包的作用

客棧

我們知道,在函式內部定義的區域性變數,只能在函式內部可以使用,並且當我們使用完成後它就會被銷燬,但是有閉包以後,這個區域性變數就會在函式外部使用並且要等它的外部呼叫者呼叫完畢後才會被銷燬,所以閉包的作用就是:延伸了變數的作用範圍。

到此這篇關於JavaScript閉包closure詳述的文章就介紹到這了,更多相關JavaScript閉包內容請搜尋我們以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援我們!