iframe如何動(dòng)態(tài)創(chuàng)建及釋放其所占內(nèi)存
最近參與一個(gè)項(xiàng)目的開(kāi)發(fā),由于項(xiàng)目是基于瀏覽器的胖客戶(hù)端(RIA)應(yīng)用程序,頁(yè)面中大量調(diào)用iframe。后期測(cè)試發(fā)現(xiàn)瀏覽器內(nèi)存一直居高不下,而且打開(kāi)iframe頁(yè)面越多內(nèi)存占用越大,在IE系列瀏覽器中尤其明顯。所有打開(kāi)的iframe頁(yè)面即使關(guān)閉了,內(nèi)存使用也沒(méi)有明顯的下降,IE瀏覽器在內(nèi)存占用達(dá)到400M左右就變得很卡。分析發(fā)現(xiàn)是iframe沒(méi)有釋放造成的,于是對(duì)所有已關(guān)閉的iframe所占用的內(nèi)存進(jìn)行釋放,雖然不能完全釋放,但是iframe內(nèi)存占用量不會(huì)一直增長(zhǎng),整個(gè)應(yīng)用內(nèi)存使用量控制在150M左右。
/**
* 動(dòng)態(tài)創(chuàng)建iframe
* @param dom 創(chuàng)建iframe的容器,即在dom中創(chuàng)建iframe。dom可以是div、span或者其他標(biāo)簽。
* @param src iframe中打開(kāi)的網(wǎng)頁(yè)路徑
* @param onload iframe加載完后觸發(fā)該事件,可以為空
* @return 返回創(chuàng)建的iframe對(duì)象
*/
function createIframe(dom, src, onload){
//在document中創(chuàng)建iframe
var iframe = document.createElement("iframe");
//設(shè)置iframe的樣式
iframe.style.width = '100%';
iframe.style.height = '100%';
iframe.style.margin = '0';
iframe.style.padding = '0';
iframe.style.overflow = 'hidden';
iframe.style.border = 'none';
//綁定iframe的onload事件
if(onload && Object.prototype.toString.call(onload) === '[object Function]'){
if(iframe.attachEvent){
iframe.attachEvent('onload', onload);
}else if(iframe.addEventListener){
iframe.addEventListener('load', onload);
}else{
iframe.onload = onload;
}
}
iframe.src = src;
//把iframe加載到dom下面
dom.appendChild(iframe);
return iframe;
}
/**
* 銷(xiāo)毀iframe,釋放iframe所占用的內(nèi)存。
* @param iframe 需要銷(xiāo)毀的iframe對(duì)象
*/
function destroyIframe(iframe){
//把iframe指向空白頁(yè)面,這樣可以釋放大部分內(nèi)存。
iframe.src = 'about:blank';
try{
iframe.contentWindow.document.write('');
iframe.contentWindow.document.clear();
}catch(e){}
//把iframe從頁(yè)面移除
iframe.parentNode.removeChild(iframe);
}
相關(guān)文章
關(guān)于JSON與JSONP簡(jiǎn)單總結(jié)
JSON(JavaScript Object Notation) 是一種輕量級(jí)的數(shù)據(jù)交換格式。而JSONP(JSON with Padding)是資料格式 JSON 的一種“使用模式”。下面是小編總結(jié)的關(guān)于JSON與JSONP知識(shí),感興趣的朋友一起看下吧2016-08-08
JavaScript?Array.from及其相關(guān)用法詳解(示例演示)
Array.from方法是ES6引入的一個(gè)靜態(tài)方法,用于從類(lèi)數(shù)組對(duì)象或可迭代對(duì)象創(chuàng)建一個(gè)新的數(shù)組實(shí)例,本文將詳細(xì)介紹Array.from的基本用法、實(shí)際場(chǎng)景中的應(yīng)用,以及它如何與其他JavaScript特性相結(jié)合提升代碼的簡(jiǎn)潔性和可讀性,感興趣的朋友一起看看吧2025-03-03
JavaScript中正則表達(dá)式判斷匹配規(guī)則及常用方法
JS作為一門(mén)常用于web開(kāi)發(fā)的語(yǔ)言,必然要具備正則這種強(qiáng)大的特性,本文將對(duì)JS中的正則用法及常用函數(shù)進(jìn)行一番總結(jié)2017-08-08
微信小程序之swiper輪播圖中的圖片自適應(yīng)高度的方法
這篇文章主要介紹了微信小程序之swiper輪播圖中的圖片自適應(yīng)高度的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-04-04
Electron 結(jié)合 Selenium + chromedriver 
這篇文章主要介紹了Electron 結(jié)合 Selenium + chromedriver 驅(qū)動(dòng)服務(wù)實(shí)現(xiàn)瀏覽器多開(kāi)思路詳解,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2024-07-07
JS實(shí)現(xiàn)用特殊符號(hào)替換字符串的中間部分區(qū)域的實(shí)例代碼
相信很多人都遇到過(guò)敏感信息需要做部分隱藏功能,大多數(shù)都是用特殊符號(hào)去替換。今天小編給大家?guī)?lái)了JS實(shí)現(xiàn)用特殊符號(hào)替換字符串的中間部分區(qū)域的實(shí)例代碼,需要的朋友參考下吧2018-07-07
JS實(shí)現(xiàn)簡(jiǎn)易留言板(節(jié)點(diǎn)操作)
這篇文章主要為大家詳細(xì)介紹了JS實(shí)現(xiàn)簡(jiǎn)易留言板,節(jié)點(diǎn)進(jìn)行操作,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-03-03
DEDECMS如何為文章添加HOT NEW標(biāo)志圖片
再用織夢(mèng)建站的時(shí)候,常常需要要在列表頁(yè)添加前兩天的文章后面添加個(gè)new小圖片,那么此功能是怎么實(shí)現(xiàn)的呢,下面通過(guò)本文給大家詳解dedecms為文章添加HOT NEW標(biāo)志圖片,需要的朋友可以參考下2015-08-08
layui實(shí)現(xiàn)給某一列加點(diǎn)擊事件
今天小編就為大家分享一篇layui實(shí)現(xiàn)給某一列加點(diǎn)擊事件,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-10-10

