JQuery关于DOM的释放

[quote]
JQuery关于DOM的释放

JQuery的empty()和 remove()
empty()是调用remove()来进行清空的,
而remove()则是先清理所有选中的对象及其子对象的所有事件和属性,再使用removeChild()删除自己.
经在IE6下测试,removeChild()有两个很重要特性:
第一,他不会删除DOM中的事件
第二,他不会真正删除(释放)指定对象中的子对象
而JQuery就是犯了第二条, 结果所有子对象都成为了不在DOM树中的“游离子DOM树”,这时JS是无能为力了(因为已经没有引用地址,例如变量名),即使使用CollectGarbage();都不能释放内存
解决方案(伪代码):
jQuery( “*”, obj).add([obj]).each(function(){
jQuery.event.remove(this);
jQuery.removeData(this);
});
obj.innerHTML = “”;
PS.:
上面代码意思是:使用JQuery把指定对象及所有子对象的事件和属性去除,这是由于使用innerHTML和removeChild()一样也不能清除对象的事件,然后使用innerHTML=”” 来清空内容,使用innerHTML=”能把所有子对象都完全清空.
[/quote]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值