javascript 常見的閉包問題的解決辦法
更新時間:2009年11月06日 00:15:04 作者:
javascript 常見的閉包問題的解決辦法,需要的朋友可以參考下。
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執(zhí)行]
上段代碼本意是在每個div上都加一個事件,即每當(dāng)點擊div時,就顯示此div的相應(yīng)序號。但是運行程序時我們會發(fā)現(xiàn),不論點擊那個,只會顯示7,這是什么愿因呢。--這就是閉包的問題
原來 在js中,函數(shù)中在定義函數(shù),就出現(xiàn)閉包了。此時外層函數(shù)中變量是可以在里層函數(shù)里利用的,即使外層函數(shù)結(jié)束。但是當(dāng)外層中出現(xiàn)循環(huán)的時候,如果在里層函數(shù)中利用這個循環(huán)變量的話,會直接引用這個變量的最終值。
就像上述代碼演示的一樣。
如何解決呢。
可以利用匿名函數(shù)來加以解決。匿名函數(shù)會制動執(zhí)行,我們可以利用這一特性,來產(chǎn)生一個作用域,生命一個變量,來引用外層的循環(huán)變量。
如代碼所示:
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執(zhí)行]
由于在內(nèi)層函數(shù)里只要出現(xiàn)循環(huán)變量的話 都是最終值,所以我們利用匿名函數(shù) 激發(fā)出一個作用域,在進(jìn)入內(nèi)層循環(huán)之前,有另一變量獲得該循環(huán)變量的值,這一思想是處理閉包問題的精髓。
如下例子:此時并沒有明顯的for循環(huán),但是 根據(jù)上述思想,可以立即加以解決 問題
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執(zhí)行]
解決后代碼:
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執(zhí)行]
補(bǔ)充:看到有網(wǎng)友這樣解決了問題:
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執(zhí)行]
我個人的理解是 在進(jìn)入內(nèi)層循環(huán)之前 把id賦值給f,f在作為內(nèi)層循環(huán)的參數(shù),其思想應(yīng)該是一樣的.
相關(guān)文章
Js為表單動態(tài)添加節(jié)點內(nèi)容的方法
這篇文章主要介紹了Js為表單動態(tài)添加節(jié)點內(nèi)容的方法,實例分析了js針對表單節(jié)點進(jìn)行添加操作的常用技巧,需要的朋友可以參考下2015-02-02js判斷樣式className同時增加class或刪除class
用正則表達(dá)式判斷多個class之間是否存在真正的class(前后空格的處理)然后增加class刪除class,本文給予實現(xiàn)方法,感興趣的朋友可以了解下,或許對你有所幫助2013-01-01JavaScript中string轉(zhuǎn)換成number介紹
這篇文章主要介紹了JavaScript中string轉(zhuǎn)換成number介紹,本文講解了3種將string值轉(zhuǎn)換成number的方法,需要的朋友可以參考下2014-12-12JavaScript Event事件學(xué)習(xí)第一章 Event介紹
Events是每一個JavaScript程序核心。什么是事件處理,它有什么問題和怎樣寫出跨瀏覽器的代碼,我將在這一章做一個概述。我也會提供一些有精彩的關(guān)于事件處理程序的細(xì)節(jié)的文章。2010-02-02