您好,登錄后才能下訂單哦!
這篇文章主要介紹了JavaScript在IE9之前版本中內存泄露問題的示例分析,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
IE9之前的版本對JScript對象和COM對象使用不同的垃圾回收例程(COM對象采用“引用計數”收集策略),因此閉包在IE的這些版本中會導致一些特殊問題。具體來說,如果閉包的作用域中保存著一個HTML元素,那么就意味著該元素將無法被銷毀。
來看下面的例子:
function assignHandler() { var elem = document.getElementById('elem_id'); elem.onclick = function(evt) { alert(elem.id); }; }
以上代碼創建了一個作為elem元素事件處理程序的閉包,而這個閉包則又創建了一個循環引用。由于匿名函數保存了一個對assignHandler()的活動對象的引用,因此就會導致無法減少elem的引用數。只要匿名函數存在,elem的引用數至少也是1,因此它所占用的內存就永遠不會被回收。
可以將上面的代碼稍作修改一下就可以解決:
function assignHandler() { var elem = document.getElementById('elem_id'); var elem_id = elem.id; elem.onclick = function(evt) { alert(elem_id); }; elem = null; }
通過把elem.id的一個副本保存在一個變量中,并且在閉包中引用該變量消除了循環引用。但僅僅做到這一步,還是不能解決內存泄露問題。
“閉包會引用包含函數的整個活動對象,而其中就包含著elem。即使閉包不直接引用elem,包含函數的活動對象中也仍然會保存一個引用。因此,有必要把elem設置為null。這樣就能解除對DOM對象的引用,順利地減少其引用數,確保正常回收其占用的內存”
感謝你能夠認真閱讀完這篇文章,希望小編分享的“JavaScript在IE9之前版本中內存泄露問題的示例分析”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。