欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript閉包closure詳述

 更新時間:2022年06月07日 09:26:21   作者:bear*6  
這篇文章主要大家分享的是JavaScript閉包詳述,在JavaScript部分,閉包是很重要的東西,所以我們今天就閉包的相關知識做一個總結,需要的朋友可以參考一下,希望對你有所幫助

前言:

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

一、什么是閉包

閉包(closure)指有權訪問另一個函數(shù)作用域中變量的函數(shù)。 ----- JavaScript 高級程序設計

簡單理解閉包就是一個函數(shù),他的特點是:一個作用域可以訪問另外一個函數(shù)內部的局部變量。

舉個簡單的例子:

比如說我們現(xiàn)在有一個函數(shù),在他的內部我們定義了一個局部變量,如果別的作用域可以訪問這個局部變量,就產生了閉包。所以我們在該函數(shù)內部再定義另一個函數(shù),看看里面的函數(shù)作用域是否可以訪問外函數(shù)中的局部變量。

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

打印的結果為:

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

我們將f2函數(shù)的調用改為f1函數(shù)的返回值,然后在函數(shù)外面調用f1函數(shù),如下:

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

此時,就相當于f1外部的作用域訪問其內部函數(shù)的變量。打印結果為:

可以發(fā)現(xiàn),這里也可以使用其內部的局部變量,閉包產生。

所以可以得出結論:

閉包: 一個作用域可以訪問另外一個函數(shù)內部的局部變量。

二、閉包的作用

我們知道,在函數(shù)內部定義的局部變量,只能在函數(shù)內部可以使用,并且當我們使用完成后它就會被銷毀,但是有閉包以后,這個局部變量就會在函數(shù)外部使用并且要等它的外部調用者調用完畢后才會被銷毀,所以閉包的作用就是:延伸了變量的作用范圍。

到此這篇關于JavaScript閉包closure詳述的文章就介紹到這了,更多相關JavaScript閉包內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

最新評論