摘要:但是函數(shù)返回了內(nèi)部函數(shù),內(nèi)部函數(shù)會隨時訪問變量所以垃圾回收機制是不會回收函數(shù)的內(nèi)部作用域的,這就是閉包的含義。也就是函數(shù)在定義的詞法作用域以外的地方被調(diào)用,閉包使得函數(shù)可以繼續(xù)訪問定義時的詞法作用域。
初學JavaScript閉包時,閉包這個概念在我眼里及其的神秘,也不知道這個東西在講什么,尤其某些地方的閉包概念定義的非常抽象,屬于那種本來你可能明白這個概念,看了反而又把你給繞糊涂了,學習了這么長時間的JavaScript,看了不少的書,對閉包的這個概念也算是稍稍有點體會的了,這里順便推薦兩本書《你不知道的JavaScript》和《JavaScript忍者秘籍》。
之前有次面試的時候,面試官讓我寫一個閉包的例子,我就寫了下面的代碼:
var a = 100; (function(){ console.log(a); //100 })();
上面這個例子從廣義上講確實算是一個閉包的例子,但是實質(zhì)上講其實算是一個詞法作用域的例子,其中涉及到RHS。但卻不是一個很合適的講述閉包的例子,后面看到一個例子算是一個比較好解釋閉包的代碼:
function fn(){ var a = 100; function func(){ console.log(a); } return func; } var func = fn(); func(); //100
這個例子才算是一個比較好的閉包的概念。
當函數(shù)可以記住并訪問所在的詞法作用域時,就產(chǎn)生了閉包,即使函數(shù)是在當前的詞法作用域之外的執(zhí)行的。
上面這個概念是引申自《你所不知道的JavaScript》中,變量a定義在函數(shù)fn()的作用域中,并且函數(shù)fn()中含有一個內(nèi)部函數(shù)func(),內(nèi)部函數(shù)func()持有對變量a的引用。在正常情況下,當函數(shù)func執(zhí)行后就,內(nèi)部的變量就會被垃圾回收機制所回收(比如變量a)。但是函數(shù)fn()返回了內(nèi)部函數(shù)func(),內(nèi)部函數(shù)func()會隨時訪問變量a,所以垃圾回收機制是不會回收函數(shù)fn()的內(nèi)部作用域的,這就是閉包的含義。也就是
函數(shù)在定義的詞法作用域以外的地方被調(diào)用,閉包使得函數(shù)可以繼續(xù)訪問定義時的詞法作用域。
現(xiàn)在你對閉包的理解會不會有種恍然大悟的感覺呢?如果沒有?那建議看看《你所不知道的JavaScript》和《JavaScript忍者秘籍》這兩本書,里面對閉包講解的都非常的棒。
文章版權歸作者所有,未經(jīng)允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉載請注明本文地址:http://systransis.cn/yun/81142.html
摘要:在內(nèi)部,理所當然能訪問到局部變量,但當作為的返回值賦給外的全局變量時,神奇的事情發(fā)生了在全局作用域中訪問到了,這就是閉包。而閉包最神奇的地方就是能在一個函數(shù)外訪問函數(shù)中的局部變量,把這些變量用閉包的形式放在函數(shù)中便能避免污染。 一、閉包是什么? 《JavaScript高級程序設計》中寫道:閉包是指有權訪問另一個函數(shù)作用域中的變量的函數(shù),如果用下定義的觀點看,這句話就是說閉包是函數(shù),我...
摘要:我們可以用普通函數(shù)內(nèi)部嵌套匿名函數(shù),形成一個閉包來使變量駐留在內(nèi)存中。局部變量閉包為什么要將賦值給變量呢這里我們就要談到匿名函數(shù)調(diào)用問題匿名函數(shù)如何調(diào)用還是上面的例子會將整個函數(shù)體打印出來這樣才調(diào)用了函數(shù)內(nèi)部的匿名函數(shù)看到這里。 閉包含義: 閉包是指有權訪問另一個函數(shù)作用域中的變量的函數(shù),創(chuàng)建閉包的常見的方式,就是在一個函數(shù)內(nèi)部創(chuàng)建另一個函數(shù),通過另一個函數(shù)訪問這個函數(shù)的局部變量。 這...
摘要:將作用域賦值給變量這里的作用域是,而不是將作用域賦值給一個變量閉包返回瀏覽器中內(nèi)存泄漏問題大家都知道,閉包會使變量駐留在內(nèi)存中,這也就導致了內(nèi)存泄漏。 上一章我們講了匿名函數(shù)和閉包,這次我們來談談閉包中作用域this的問題。 大家都知道,this對象是在運行時基于函數(shù)的執(zhí)行環(huán)境綁定的,如果this在全局就是[object window],如果在對象內(nèi)部就是指向這個對象,而閉包卻是在運行...
摘要:關于循環(huán)和閉包當循環(huán)和閉包結合在一起時,經(jīng)常會產(chǎn)生讓初學者覺得匪夷所思的問題。閉包是一把雙刃劍是比較難以理解和掌握的部分,它十分強大,卻也有很大的缺陷,如何使用它完全取決于你自己。 在談閉包之前,我們首先要了解幾個概念: 什么是函數(shù)表達式? 與函數(shù)聲明有何不同? JavaScript查找標識符的機制 JavaScript的作用域是詞法作用域 JavaScript的垃圾回收機制 先來...
閱讀 3901·2021-07-28 18:10
閱讀 2607·2019-08-30 15:44
閱讀 1122·2019-08-30 14:07
閱讀 3490·2019-08-29 17:20
閱讀 1604·2019-08-26 18:35
閱讀 3561·2019-08-26 13:42
閱讀 1848·2019-08-26 11:58
閱讀 1619·2019-08-23 18:33