<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        IEJS編程需注意的內存釋放問題_javascript技巧

        來源:懂視網 責編:小采 時間:2020-11-27 20:43:15
        文檔

        IEJS編程需注意的內存釋放問題_javascript技巧

        IEJS編程需注意的內存釋放問題_javascript技巧:1、給DOM對象添加的屬性是一個對象的引用。范例:var MyObject = {};document.getElementById('myDiv').myProp = MyObject;解決方法:在window.onunload事件中寫上: document.getElementById('myDiv').myProp =
        推薦度:
        導讀IEJS編程需注意的內存釋放問題_javascript技巧:1、給DOM對象添加的屬性是一個對象的引用。范例:var MyObject = {};document.getElementById('myDiv').myProp = MyObject;解決方法:在window.onunload事件中寫上: document.getElementById('myDiv').myProp =

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


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


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


        4、從外到內執行appendChild。這時即使調用removeChild也無法釋放。范例:
        var parentDiv = document.createElement("div");
        var childDiv = document.createElement("div");
        document.body.appendChild(parentDiv);
        parentDiv.appendChild(childDiv);
        解決方法:
        從內到外執行appendChild:
        var parentDiv = document.createElement("div");
        var childDiv = document.createElement("div");
        parentDiv.appendChild(childDiv);
        document.body.appendChild(parentDiv);


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


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

        2、對于第一條,事實上包括 element.onclick = funcRef 這種寫法也算在其中,因為這也是一個對對象的引用。在頁面onunload時應該釋放掉。

        3、對于第三條,在MSDN的英文說明中好像是說即使調用detachEvent也無法釋放內存,因為在attachEvent的時候就已經造成內存“LEAK”了,不過detachEvent后情況還是會好一點。不知道是不是這樣,請英文好的親能夠指出。

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

        研究 jsvm 的時候,發現 js.lang.System 里面定義了 gc() 方法

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

        CollectGarbage() 是ie特有的一個釋放內存函數

        聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        IEJS編程需注意的內存釋放問題_javascript技巧

        IEJS編程需注意的內存釋放問題_javascript技巧:1、給DOM對象添加的屬性是一個對象的引用。范例:var MyObject = {};document.getElementById('myDiv').myProp = MyObject;解決方法:在window.onunload事件中寫上: document.getElementById('myDiv').myProp =
        推薦度:
        標簽: 內存 IE js
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 国产AV无码专区亚洲A∨毛片| 国产亚洲婷婷香蕉久久精品| 日韩在线视频免费看| 国产乱子影视频上线免费观看| 国产AV无码专区亚洲精品| 日韩毛片免费一二三| 亚洲中文无码永久免费| 亚洲国产另类久久久精品小说| 久久久WWW成人免费精品| 成人无遮挡裸免费视频在线观看| 亚洲国产成人高清在线观看| 日韩精品无码免费专区午夜 | 亚洲国产美女精品久久久| 97无码人妻福利免费公开在线视频| 国产精一品亚洲二区在线播放| 成人性生交大片免费看中文| 久久亚洲AV无码精品色午夜麻| jzzijzzij在线观看亚洲熟妇| 99热这里只有精品6免费| 亚洲情侣偷拍精品| 亚洲AV无码精品国产成人| 最近的中文字幕大全免费8| 精品国产亚洲男女在线线电影| 亚洲中文字幕无码爆乳app| 四虎最新永久免费视频| 亚洲精品自产拍在线观看动漫| 国产高清视频免费在线观看 | 亚洲人成网站色7799| 亚洲高清视频免费| 久久国产精品亚洲综合| 男女免费观看在线爽爽爽视频| 亚洲Aⅴ无码专区在线观看q| 蜜臀AV免费一区二区三区| 亚洲中文字幕久久精品无码VA| 免费一级毛片在线观看| 国产成人不卡亚洲精品91| 日本19禁啪啪无遮挡免费动图| www免费插插视频| 亚洲AV无码一区二区三区国产| 国产亚洲精品2021自在线| 国产亚洲综合久久系列|