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

IE JS編程需注意的內(nèi)存釋放問(wèn)題

 更新時(shí)間:2009年06月23日 00:31:14   作者:  
在IE下的JS編程中,以下的編程方式都會(huì)造成即使關(guān)閉IE也無(wú)法釋放內(nèi)存的問(wèn)題,下面分類給出

1、給DOM對(duì)象添加的屬性是一個(gè)對(duì)象的引用。范例:
var MyObject = {};
document.getElementById('myDiv').myProp = MyObject;
解決方法:
在window.onunload事件中寫上: document.getElementById('myDiv').myProp = null;


2、DOM對(duì)象與JS對(duì)象相互引用。范例:
function Encapsulator(element) {
    this.elementReference = element;
    element.myProp = this;
}
new    Encapsulator(document.getElementById('myDiv'));
解決方法:
在onunload事件中寫上: document.getElementById('myDiv').myProp = null;


3、給DOM對(duì)象用attachEvent綁定事件。范例:
function doClick() {}
element.attachEvent("onclick", doClick);
解決方法:
在onunload事件中寫上: element.detachEvent('onclick', doClick);


4、從外到內(nèi)執(zhí)行appendChild。這時(shí)即使調(diào)用removeChild也無(wú)法釋放。范例:
var parentDiv =    document.createElement("div");
var childDiv = document.createElement("div");
document.body.appendChild(parentDiv);
parentDiv.appendChild(childDiv);
解決方法:
從內(nèi)到外執(zhí)行appendChild:
var parentDiv =    document.createElement("div");
var childDiv = document.createElement("div");
parentDiv.appendChild(childDiv);
document.body.appendChild(parentDiv);


5、反復(fù)重寫同一個(gè)屬性會(huì)造成內(nèi)存大量占用(但關(guān)閉IE后內(nèi)存會(huì)被釋放)。范例:
for(i = 0; i < 5000; i++) {
    hostElement.text = "asdfasdfasdf";
}
這種方式相當(dāng)于定義了5000個(gè)屬性!
解決方法:
其實(shí)沒(méi)什么解決方法:P~~~就是編程的時(shí)候盡量避免出現(xiàn)這種情況咯~~


說(shuō)明:
1、以上資料均來(lái)源于微軟官方的MSDN站點(diǎn),鏈接地址:
http://msdn.microsoft.com/librar ... e_leak_patterns.asp
大家可以到上面這個(gè)地址中看到詳細(xì)的說(shuō)明,包括范例和圖例都有。只是我英文不太好,看不太懂,如果我上述有失誤或有需要補(bǔ)充的地方請(qǐng)大家指出。

2、對(duì)于第一條,事實(shí)上包括 element.onclick = funcRef 這種寫法也算在其中,因?yàn)檫@也是一個(gè)對(duì)對(duì)象的引用。在頁(yè)面onunload時(shí)應(yīng)該釋放掉。

3、對(duì)于第三條,在MSDN的英文說(shuō)明中好像是說(shuō)即使調(diào)用detachEvent也無(wú)法釋放內(nèi)存,因?yàn)樵赼ttachEvent的時(shí)候就已經(jīng)造成內(nèi)存“LEAK”了,不過(guò)detachEvent后情況還是會(huì)好一點(diǎn)。不知道是不是這樣,請(qǐng)英文好的親能夠指出。

4、在實(shí)際編程中,這些內(nèi)存問(wèn)題的實(shí)際影響并不大,尤其是給客戶使用時(shí),客戶對(duì)此絕不會(huì)有察覺(jué),然而這些問(wèn)題對(duì)于程序員來(lái)說(shuō)卻始終是個(gè)心病 --- 有這樣的BUG心里總會(huì)覺(jué)得不舒服吧?能解決則給與解決,這樣是最好的。事實(shí)上我在webfx.eae.net這樣頂級(jí)的JS源碼站點(diǎn)中,在它們的源碼里都會(huì)看到采用上述解決方式進(jìn)行內(nèi)存的釋放管理。

研究 jsvm 的時(shí)候,發(fā)現(xiàn) js.lang.System 里面定義了 gc() 方法

System.gc = function ()
{
  if (System.isIeBrowser())
  {
    CollectGarbage();
    setTimeout("CollectGarbage();", 1);
  }
}

CollectGarbage() 是ie特有的一個(gè)釋放內(nèi)存函數(shù)

相關(guān)文章

  • 微信小程序onLaunch異步,首頁(yè)onLoad先執(zhí)行?

    微信小程序onLaunch異步,首頁(yè)onLoad先執(zhí)行?

    這篇文章主要介紹了微信小程序onLaunch異步,首頁(yè)onLoad先執(zhí)行? 文章底部給大家介紹了小程序_onLaunch異步回調(diào)數(shù)據(jù)加載問(wèn)題的兩種解決方案,需要的朋友可以參考下
    2018-09-09
  • 詳解JS如何判斷對(duì)象上是否存在某個(gè)屬性

    詳解JS如何判斷對(duì)象上是否存在某個(gè)屬性

    判斷某一個(gè)對(duì)象里面是否存在某個(gè)屬性,是常見錯(cuò)誤場(chǎng)景排查,但是你真的知道該如何使用嘛,本文為大家整理了常用的三種方法,希望對(duì)大家有所幫助
    2023-05-05
  • javascript事件函數(shù)中獲得事件源的兩種不錯(cuò)方法

    javascript事件函數(shù)中獲得事件源的兩種不錯(cuò)方法

    許多情況我們需要獲得事件源對(duì)象來(lái)對(duì)其屬性進(jìn)行更改,在事件響應(yīng)函數(shù)中獲得事件源的方法有如下兩種
    2014-03-03
  • JavaScript中Require調(diào)用js的實(shí)例分享

    JavaScript中Require調(diào)用js的實(shí)例分享

    下面小編就為大家?guī)?lái)一篇JavaScript中Require調(diào)用js的實(shí)例分享。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-10-10
  • 前端接口報(bào)錯(cuò)Required?request?body?is?missing解決辦法

    前端接口報(bào)錯(cuò)Required?request?body?is?missing解決辦法

    這篇文章主要給大家介紹了關(guān)于前端接口報(bào)錯(cuò)Required?request?body?is?missing的解決辦法,文中通過(guò)代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-12-12
  • javascript奇異的arguments分析

    javascript奇異的arguments分析

    在 Javascript 的函數(shù)中有個(gè)名為 arguments 的類數(shù)組對(duì)象。它看起來(lái)是那么的詭異而且名不經(jīng)傳,但眾多的 Javascript 庫(kù)都使用著它強(qiáng)大的功能。所以,它的特性需要每個(gè) Javascript 程序員去熟悉它。
    2010-10-10
  • javascript 拖放效果實(shí)現(xiàn)代碼

    javascript 拖放效果實(shí)現(xiàn)代碼

    JavaScript擅長(zhǎng)于修改頁(yè)面中的DOM元素,但是我們使用JavaScript通常只是實(shí)現(xiàn)一些簡(jiǎn)單功能,例如實(shí)現(xiàn)圖片的翻轉(zhuǎn),網(wǎng)頁(yè)中的標(biāo)簽頁(yè),等等。這篇文章將向你展示如何在頁(yè)面中,對(duì)創(chuàng)建的元素實(shí)現(xiàn)拖放。
    2010-01-01
  • bootstrap select2插件用ajax來(lái)獲取和顯示數(shù)據(jù)的實(shí)例

    bootstrap select2插件用ajax來(lái)獲取和顯示數(shù)據(jù)的實(shí)例

    今天小編就為大家分享一篇bootstrap select2插件用ajax來(lái)獲取和顯示數(shù)據(jù)的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-08-08
  • jQuery實(shí)現(xiàn)動(dòng)態(tài)添加、刪除按鈕及input輸入框的方法

    jQuery實(shí)現(xiàn)動(dòng)態(tài)添加、刪除按鈕及input輸入框的方法

    這篇文章主要介紹了jQuery實(shí)現(xiàn)動(dòng)態(tài)添加、刪除按鈕及input輸入框的方法,涉及jQuery事件響應(yīng)及頁(yè)面元素動(dòng)態(tài)操作相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下
    2017-04-04
  • js實(shí)現(xiàn)簡(jiǎn)單的選項(xiàng)卡效果

    js實(shí)現(xiàn)簡(jiǎn)單的選項(xiàng)卡效果

    本文主要介紹了js實(shí)現(xiàn)簡(jiǎn)單的選項(xiàng)卡效果的示例代碼,具有很好的參考價(jià)值,下面跟著小編一起來(lái)看下吧
    2017-02-02

最新評(píng)論