前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >EonerCMS——做一个仿桌面系统的CMS(十-附最新源码)

EonerCMS——做一个仿桌面系统的CMS(十-附最新源码)

作者头像
胡尐睿丶
发布2022-03-23 16:35:52
2100
发布2022-03-23 16:35:52
举报
文章被收录于专栏:代码小睿

  废话不多说,继上次遗留的问题——内存泄漏

  趁周末,查了好多资料,也问了好多JS高手,大致是这么个情况。因为我每打开一个窗口,就绑定了一个永久性的dom元素,而dom元素的回收是靠计数器,计数器是会累加的,如果没有清零,即便删掉了节点,其实还是驻留在内存中。

  既然大致明白了原理,处理起来就相对比较简单了,就一句话,首先先看下原先的关闭窗口的代码

代码语言:javascript
复制
	//关闭
	$('.task-window li[window="'+obj.attr('window')+'"]').remove();
	obj.fadeOut("500",function(){$(this).remove();});

  修改后

代码语言:javascript
复制
	//关闭
	$('.task-window li[window="'+obj.attr('window')+'"]').remove();
	obj.fadeOut("500",function(){$(this).html("").remove();});

  我们看到,其实我就是先清空了html代码,然后再删除了节点。

  然后这次我还更新了事件绑定,因为窗口的创建、关闭、移动等事件,其实都是一样的,所以事件绑定我单独拎了出来,而非创建dom元素的时候进行绑定,这样只需注册一次,而且这样也能减少内存的占用吧,这个我没研究过,希望有人能帮我解答下,事件越多是不是内存也会占用越多?

  这次就更新了这些,写的比较少,因为代码修改没花太多时间,大部分都在学习和思考上,因为自己本身对js的生命周期、内存释放/泄漏不太了解,所以就花了点时间去了解,写的不对的地方,还希望大家指出。

  测试地址:http://saw.caifutang.com/eonercms

  源码:点击下载

  PS:IE下测试内存占用的小工具sIEve,如何使用可以看下这个链接,感觉还挺好用的。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2011-11-07 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档