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

javascript 避免閉包引發(fā)的問題

 更新時間:2009年03月17日 23:37:22   作者:  
閉包的功能強大,但如果沒有正確理解閉包的概念,其結果往往出乎人的意料。例如,下面是一個較常見的問題
<div id="test">
<div>第一個</div>
<div>第二個</div>
<div>第三個</div>
<div>第四個</div>
</div>
<script>
function test()
{
var els = document.getElementById("test").getElementsByTagName("div");
for (var i = 0; i < els.length; i++)
{
var div = els[i];
div.onclick = function()
{
alert(div.innerHTML);
return false;
}
}
}
test();
</script>
無論我們點擊哪個div,反饋的都是第4個div的內容。究其原因,在于每個div的點擊事件都與test方法形成了閉包,且每個div的點擊事件都共享同一個閉包作用域鏈。當事件被觸發(fā)時,變量i所代表的下標已經指向第4個div。可以采用以下幾種方式避免由于閉包引起的問題。
(1)使用this轉換閉包的作用域鏈上下文,上例的閉包可以改寫為:
for (var i = 0; i < els.length; i++)
{
var div = els[i];
div.onclick = function()
{
alert(this.innerHTML);
return false;
}
}
當點擊div的事件被觸發(fā)時,查找的作用域已經是“this”所指定的上下文。盡管該事件仍然處于“test”閉包內,但由于不訪問或不使用閉包的上下文環(huán)境,也就不存在由于閉包作用域內變量被引用所引發(fā)的問題。
(2)使點擊div的事件與for循環(huán)形成閉包,而使得for循環(huán)內的變量div不被回收。如:
//for循環(huán)內定義閉包方法
for (var i = 0; i < els.length; i++)
{
var div = els[i];
a(div);
function a(o)
{
o.onclick = function()
{
alert(o.innerHTML);
}
}
}
//for循環(huán)外定義閉包方法
for (var i = 0; i < els.length; i++)
{
var div = els[i];
a(div);
}
function a(o)
{
o.onclick = function()
{
alert(o.innerHTML);
}
}
//使用匿名方法,其原理與for循環(huán)內定義類似
for (var i = 0; i < els.length; i++)
{
var div = els[i];
(function(o)
{
o.onclick = function()
{
alert(o.innerHTML);
}
})(div);
}
通過中間方法a或者匿名方法,使for循環(huán)體與onclick事情產生閉包。
(3)控制變量的作用域,使點擊div的事件所需變量與外層作用域無關。如:
for (var i = 0; i < els.length; i++)
{
(function()
{
var div = els[i];
div.onclick = function()
{
alert(div.innerHTML);
}
})();
}
內部函數自身也可能有內部函數。每次作用域鏈嵌套,都會增加由創(chuàng)建內部函數對象的執(zhí)行環(huán)境所引發(fā)的新活動對象。ECMA262規(guī)范要求作用域鏈是臨時性的,但對作用域鏈的長度卻沒有加以限制。閉包的潛規(guī)則即Function與內部定義的Function之間的相互作用域鏈上下文環(huán)境的關系。如果運用得當,嵌套的內部函數所擁有的潛能將超出了我們的想象力。

相關文章

  • javascript parseInt 大改造

    javascript parseInt 大改造

    還隱約記得第一次遇到 parseInt這個詭異問題的時候,以為發(fā)現了IE的BUG,興奮不已。
    2009-09-09
  • JavaScript之BOM構成和常用事件詳解

    JavaScript之BOM構成和常用事件詳解

    這篇文章主要為大家介紹了JavaScript BOM構成和常用事件,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-12-12
  • JavaScript實現音樂自動切換和輪播

    JavaScript實現音樂自動切換和輪播

    這篇文章主要為大家詳細介紹了JavaScript實現音樂自動切換和輪播效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-11-11
  • 純JS代碼實現氣泡效果

    純JS代碼實現氣泡效果

    js氣泡效果,在項目需求中經常遇到。今天小編把大概實現步驟分享到腳本之家平臺,感興趣的朋友可以參考下
    2016-05-05
  • javascript trie前綴樹的示例

    javascript trie前綴樹的示例

    這篇文章主要介紹了javascript trie單詞查找樹的示例,詳細的介紹了trie的概念和實現,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-01-01
  • 深入理解JavaScript中的for循環(huán)

    深入理解JavaScript中的for循環(huán)

    這篇文章主要給大家深入的介紹了JavaScript中的for循環(huán),其中包括ES5中的三種for循環(huán),分別是簡單for循環(huán)、for-in以及forEach,另外還詳細介紹了ES6新增的一種循環(huán):for-of ,有需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-02-02
  • ES6新增的math,Number方法

    ES6新增的math,Number方法

    ES6新增的math,Number方法,小編覺得非常不錯,需要的朋友參考下吧
    2017-08-08
  • js實現在網頁上簡單顯示時間的方法

    js實現在網頁上簡單顯示時間的方法

    這篇文章主要介紹了js實現在網頁上簡單顯示時間的方法,實例分析了javascript實時顯示時間的技巧,需要的朋友可以參考下
    2015-03-03
  • JS?Angular?服務器端渲染應用設置渲染超時時間???????

    JS?Angular?服務器端渲染應用設置渲染超時時間???????

    這篇文章主要介紹了JS?Angular服務器端渲染應用設置渲染超時時間,???????通過setTimeout模擬一個需要5秒鐘才能完成調用的API展開詳情,需要的小伙伴可以參考一下
    2022-06-06
  • js中把JSON字符串轉換成JSON對象最好的方法

    js中把JSON字符串轉換成JSON對象最好的方法

    這篇文章主要介紹了js中把JSON字符串轉換為JSON對象最好的方法,需要的朋友可以參考下
    2014-03-03

最新評論