中文字幕日韩一区二区_国产一区二区av_国产毛片av_久久久久国产一区_色婷婷电影_国产一区二区精品

JQuery Dialog的內(nèi)存泄露問題解決方法

對(duì)于頁面來說,JQuery中的Dialog從效果上來說還可以,而且使用簡(jiǎn)單,只要短短幾行綁定的代碼就可以實(shí)現(xiàn)彈出效果。
代碼
復(fù)制代碼 代碼如下:
$('#dialog').dialog({
autoOpen: false,
width: 600,
buttons: {
"Ok": function() {
$(this).dialog("close");
},
"Cancel": function() {
$(this).dialog("close");
}
}
});

在一些JS交互性不多的一般頁面來說,沒有任何問題!但是對(duì)于交互性強(qiáng)的,需要?jiǎng)討B(tài)加載與釋放DOM的頁面來說,它就是一個(gè)悲劇的東西!為什么這樣說?大家看下下面的例子:
  一段簡(jiǎn)單的代碼,一個(gè)DIV是通過動(dòng)態(tài)加載到頁面上,然后對(duì)該DIV用Dialog進(jìn)行綁定,以達(dá)到彈出的目的!下面的test元素就是<div id="test"></div>。
代碼
復(fù)制代碼 代碼如下:
function TestAppend() {
$("#test").append('<div id="dialog"><div id="fileQueue"></div> <input type="file" name="uploadify" id="uploadify" />' +
'<a href="Javascript:upload();">上傳</a>' +
'<a href="Javascript:$(#uploadify).uploadifyClearQueue()">取消上傳</a><div>');
$('#dialog').dialog({
autoOpen: false,
width: 600,
buttons: {
"Ok": function() {
$(this).dialog("close");
},
"Cancel": function() {
$(this).dialog("close");
}
}
});
return false;
}

  接著,我需要?jiǎng)h除該DOM元素,一般來說,正常的做法都是$("#test").empty();這行簡(jiǎn)單的代碼就完成了!這樣有效嗎?!當(dāng)執(zhí)行完這樣代碼后,你再用$('#dialog')來獲取dialog元素,郁悶的事情發(fā)生了,既然獲取到了!為什么!不是已經(jīng)empty了嗎!
  下面我們來看下這一悲劇是如何造成的,
  我們把注意點(diǎn)放到$('#dialog').dialog上面,然后看看JQuery的實(shí)現(xiàn)代碼是如何寫的,當(dāng)我們跟蹤代碼到dialog類中的_create方法的時(shí)候,問題的原因找到了,看下面這段代碼:
復(fù)制代碼 代碼如下:
uiDialog = (self.uiDialog = $('<div></div>'))
.appendTo(document.body)
.hide()
.addClass(uiDialogClasses + options.dialogClass)
.css({
zIndex: options.zIndex
})
// setting tabIndex makes the div focusable
// setting outline to 0 prevents a border on focus in Mozilla
.attr('tabIndex', -1).css('outline', 0).keydown(function(event) {
if (options.closeOnEscape && event.keyCode &&
event.keyCode === $.ui.keyCode.ESCAPE) {
self.close(event);
event.preventDefault();
}
})
.attr({
role: 'dialog',
'aria-labelledby': titleId
})
.mousedown(function(event) {
self.moveToTop(false, event);
}),

  它既然也動(dòng)態(tài)創(chuàng)建一個(gè)div,而且把該div加到了Body上面,然后把dialog中的元素從<div id=test>中移除,加入到該新的div中.....
  這就是為什么我們$("#test").empty()后,卻對(duì)內(nèi)部的dialog沒有起作用了!而且這有一個(gè)最不好的一個(gè)地方,也是最容易出現(xiàn)內(nèi)存泄露的地方:它動(dòng)態(tài)的在Body中創(chuàng)建了一個(gè)div,這樣如果窗體不關(guān)閉的話,而你又在不察覺的情況下不斷的使用上面的TestAppend方法來動(dòng)態(tài)加載DOM,就會(huì)創(chuàng)建N個(gè)這樣的div!
  其實(shí)這個(gè)問題郁悶的地方不是在如何解決,而且隱藏的很深,很難發(fā)現(xiàn)!那么發(fā)現(xiàn)之后解決起來就變的簡(jiǎn)單多了:
復(fù)制代碼 代碼如下:
if ($('#dialog')[0]) {
$('#dialog').parent().empty();
$('#dialog').parent().remove();
}

當(dāng)前加上這段后代碼后,再做$("#dialog")來測(cè)試下,期望的結(jié)果終于出現(xiàn)了!dialog元素消失了!

JavaScript技術(shù)JQuery Dialog的內(nèi)存泄露問題解決方法,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 美女久久| 精品麻豆剧传媒av国产九九九 | 欧美综合在线视频 | 免费人成在线观看网站 | 日韩伦理一区二区 | 亚洲成人一区 | 日韩三级电影一区二区 | 毛片毛片毛片毛片毛片 | 天天精品在线 | 久久高清免费视频 | 欧美一区二区三区在线观看 | 色本道 | 男女免费网站 | 欧美一区不卡 | 欧美日韩久久 | 久久夜视频 | 国产一区二区在线免费观看 | 视频一区二区在线观看 | 成人视屏在线观看 | 国产中文字幕在线 | 久久剧场| 国产91在线观看 | 久久久成人网 | 1000部精品久久久久久久久 | 精品一二区 | 亚洲成av人片在线观看无码 | 91国内外精品自在线播放 | 成人在线播放网址 | 国产一区二| 国产欧美精品一区二区色综合 | 成人伊人| 久久黄网| 九九综合九九 | 国产亚洲一区二区三区 | 国产精品视频一区二区三区四蜜臂 | 国产在线精品一区 | 一级黄a视频 | 国产精品亚洲一区二区三区在线 | 色综合天天网 | 色爱区综合 | 色一情一乱一伦一区二区三区 |