javascript閉包功能與用法實(shí)例分析
本文實(shí)例講述了javascript閉包功能與用法。分享給大家供大家參考,具體如下:
理解閉包
閉包這個東西,確實(shí)是很麻煩。之前我自己的理解也是有一點(diǎn)誤差,所以今天將文章修改修改,爭取將自己的理解進(jìn)一步準(zhǔn)確化。
閉包說得通熟易懂一點(diǎn),就是指有權(quán)訪問另一個函數(shù)作用域的變量的函數(shù)。創(chuàng)建閉包的常見方式,就是在一個函數(shù)內(nèi)部創(chuàng)建另外一個函數(shù),并返回。
我們這里舉一個例子來說明,首先我們在函數(shù)f1內(nèi)部定義一個函數(shù)f2。
function f1(){ var n=999; function f2(){ alert(n); // 999 } }
f2可以訪問f1的作用域,反過來就不行了?,F(xiàn)在我們想訪問f1中的n,在外層卻訪問不到,怎么辦呢?將f2作為f1的返回值就可以了:
function f1(){ var n=999; function f2(){ alert(n); } return f2; } var result=f1(); result(); // 999
這個就是閉包。
其實(shí)也很簡單,那么閉包有什么用呢?
閉包的使用
之前的自己只知道閉包的概念,卻并不知道其存在的價(jià)值和意義。直到自己在項(xiàng)目中遇到類似的問題后,才發(fā)現(xiàn)只有閉包才能解決的情況。
閉包是使用可以帶來以下好處:
1. 希望一個變量長期駐扎在內(nèi)存中
2. 避免全局變量的污染
3. 私有成員的存在
我們剛才說到過,閉包可以讀取到函數(shù)內(nèi)部的變量,這是由于閉包后函數(shù)的堆棧不會釋放,也就是說這些值始終保持在內(nèi)存中。這是一個優(yōu)點(diǎn),也是一個缺點(diǎn)。
我們可以通過閉包來實(shí)現(xiàn)一個計(jì)數(shù)器,而不用擔(dān)心全局變量的污染:
function f1(){ var n=999; nAdd=function(){n+=1} function f2(){ alert(n); } return f2; } var result=f1(); result(); // 999 nAdd(); result(); // 1000
可以看到n一直存儲在內(nèi)存中,并沒有在f1調(diào)用后被自動清除。
我們再來看看如何通過閉包來模擬JavaScript中的私有成員:
var aaa = (function(){ var a = 1; function bbb(){ a++; alert(a); } function ccc(){ a++; alert(a); } return { b:bbb, //json結(jié)構(gòu) c:ccc } })(); aaa.b(); //2 aaa.c(); //3
這樣就可以提供指定的變量供外界訪問了。
閉包解決的問題
這是一個很常見的問題,就是利用javascript處理循環(huán)的時候,索引i的值不能有效的利用:
這里改成如下格式,形成10個閉包來解決即可:
更多關(guān)于JavaScript相關(guān)內(nèi)容可查看本站專題:《javascript面向?qū)ο笕腴T教程》、《JavaScript中json操作技巧總結(jié)》、《JavaScript切換特效與技巧總結(jié)》、《JavaScript查找算法技巧總結(jié)》、《JavaScript錯誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)》
希望本文所述對大家JavaScript程序設(shè)計(jì)有所幫助。
- 通俗易懂地解釋JS中的閉包
- JS繼承與閉包及JS實(shí)現(xiàn)繼承的三種方式
- 淺談JavaScript作用域和閉包
- JS閉包的幾種常見形式實(shí)例詳解
- JS實(shí)現(xiàn)閉包中的沙箱模式示例
- JavaScript閉包的簡單應(yīng)用
- 通過示例徹底搞懂js閉包
- JavaScript閉包和回調(diào)詳解
- 淺談JS封閉函數(shù)、閉包、內(nèi)置對象
- JavaScript閉包_動力節(jié)點(diǎn)Java學(xué)院整理
- 深入理解Javascript中的作用域鏈和閉包
- JS閉包可被利用的常見場景小結(jié)
- 利用js的閉包原理做對象封裝及調(diào)用方法
- JavaScript中閉包的詳解
- JS閉包用法實(shí)例分析
- 圖解Javascript——作用域、作用域鏈、閉包
- 輕松理解JavaScript閉包
- js中的閉包學(xué)習(xí)心得
相關(guān)文章
javascript使用中為什么10..toString()正常而10.toString()出錯呢
在JavaScript中為什么10..toString()正常,而10.toString()出錯呢?這個問題一直困擾著我,所抽時間搜集整理下,曬出來與大家分享感興趣的朋友可以了解下,希望對你們有幫助2013-01-01JavaScript Typescript基礎(chǔ)使用教程
TypeScript是Microsoft(微軟)開發(fā)的一種開源編程語言,它充分利用了JavaScript原有的對象模型,并在此基礎(chǔ)上進(jìn)行了擴(kuò)充,TypeScript設(shè)計(jì)目標(biāo)是開發(fā)大型應(yīng)用,它可以編譯成純JavaScript,編譯出來的JavaScript可以運(yùn)行在任何一種JS運(yùn)行環(huán)境中2022-12-12原生js實(shí)現(xiàn)移動開發(fā)輪播圖、相冊滑動特效
原生JS實(shí)現(xiàn)圖片自動輪播緩沖切換特效,很實(shí)用流暢的圖片輪播特效,在較現(xiàn)代的瀏覽器上展現(xiàn)的圓角效果,兼容差點(diǎn)的是直角效果,全部原生JS實(shí)現(xiàn),還是很不錯的值得大家學(xué)習(xí)并利用,推薦下載。2015-04-04javascript函數(shù)的四種調(diào)用模式
本文詳細(xì)介紹了javascript函數(shù)的四種調(diào)用模式。具有一定的參考價(jià)值,下面跟著小編一起來看下吧2017-01-01