2024年最新万恶的前端内存泄漏及万善的解决方案(1),2024年最新面试书籍推荐

最后

好了,这就是整理的前端从入门到放弃的学习笔记,还有很多没有整理到,我也算是边学边去整理,后续还会慢慢完善,这些相信够你学一阵子了。

做程序员,做前端工程师,真的是一个学习就会有回报的职业,不看出身高低,不看学历强弱,只要你的技术达到应有的水准,就能够得到对应的回报。

开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

学习从来没有一蹴而就,都是持之以恒的,正所谓活到老学到老,真正懂得学习的人,才不会被这个时代的洪流所淘汰。

console.log(a);

};

}

解决:将事件处理函数定义在外部,解除闭包,或者在定义事件处理函数的外部函数中。

比如:在循环中的函数表达式,能复用最好放到循环外面。

// bad

for (var k = 0; k < 10; k++) {

var t = function (a) {

// 创建了10次 函数对象。

console.log(a)

}

t(k)

}

// good

function t(a) {

console.log(a)

}

for (var k = 0; k < 10; k++) {

t(k)

}

t = null

3、没有清理的 DOM 元素引用

原因:虽然别的地方删除了,但是对象中还存在对 dom 的引用。

// 在对象中引用DOM

var elements = {

btn: document.getElementById(‘btn’),

}

function doSomeThing() {

elements.btn.click()

}

function removeBtn() {

// 将body中的btn移除, 也就是移除 DOM树中的btn

document.body.removeChild(document.getElementById(‘button’))

// 但是此时全局变量elements还是保留了对btn的引用, btn还是存在于内存中,不能被GC回收

}

解决方法:手动删除,elements.btn = null

4、被遗忘的定时器或者回调

定时器中有 dom 的引用,即使 dom 删除了,但是定时器还在,所以内存中还是有这个 dom。

// 定时器

var serverData = loadData()

setInterval(function () {

var renderer = document.getElementById(‘renderer’)

if (renderer) {

renderer.innerHTML = JSON.stringify(serverData)

}

}, 5000)

// 观察者模式

var btn = document.getElementById(‘btn’)

function onClick(element) {

element.innerHTMl = “I’m innerHTML”

}

btn.addEventListener(‘click’, onClick)

解决方法:

  • 手动删除定时器和 dom。

  • removeEventListener 移除事件监听

vue 中容易出现内存泄露的几种情况

在 Vue SPA 开发应用,那么就更要当心内存泄漏的问题。因为在 SPA 的设计中,用户使用它时是不需要刷新浏览器的,所以 JavaScript 应用需要自行清理组件来确保垃圾回收以预期的方式生效。因此开发过程中,你需要时刻警惕内存泄漏的问题。

1、全局变量造成的内存泄露

声明的全局变量在切换页面的时候没有清空

这里是首页

解决方案:在页面卸载的时候顺便处理掉该引用。

destroyed () {

window.test = null // 页面卸载的时候解除引用

}

2、监听在 window/body 等事件没有解绑

特别注意 window.addEventListener 之类的时间监听

这里是首页

解决方法:在页面销毁的时候,顺便解除引用,释放内存

mounted () {

window.addEventListener(‘resize’, this.func)

},

beforeDestroy () {

window.removeEventListener(‘resize’, this.func)

}

3、绑在 EventBus 的事件没有解绑

举个例子

这里是首页

解决方法:在页面卸载的时候也可以考虑解除引用

mounted () {

this. E v e n t B u s . EventBus. EventBus.on(‘homeTask’, res => this.func(res))

},

destroyed () {

this. E v e n t B u s . EventBus. EventBus.off()

}

4、Echarts

每一个图例在没有数据的时候它会创建一个定时器去渲染气泡,页面切换后,echarts 图例是销毁了,但是这个 echarts 的实例还在内存当中,同时它的气泡渲染定时器还在运行。这就导致 Echarts 占用 CPU 高,导致浏览器卡顿,当数据量比较大时甚至浏览器崩溃。

解决方法:加一个 beforeDestroy()方法释放该页面的 chart 资源,我也试过使用 dispose()方法,但是 dispose 销毁这个图例,图例是不存在了,但图例的 resize()方法会启动,则会报没有 resize 这个方法,而 clear()方法则是清空图例数据,不影响图例的 resize,而且能够释放内存,切换的时候就很顺畅了。

beforeDestroy () {

this.chart.clear()

}

5、v-if 指令产生的内存泄露

v-if 绑定到 false 的值,但是实际上 dom 元素在隐藏的时候没有被真实的释放掉。

比如下面的示例中,我们加载了一个带有非常多选项的选择框,然后我们用到了一个显示/隐藏按钮,通过一个 v-if 指令从虚拟 DOM 中添加或移除它。这个示例的问题在于这个 v-if 指令会从 DOM 中移除父级元素,但是我们并没有清除由 Choices.js 新添加的 DOM 片段,从而导致了内存泄漏。

<button v-if=“showChoices” @click=“hide”>Hide

<button v-if=“!showChoices” @click=“show”>Show

在上述的示例中,我们可以用 hide() 方法在将选择框从 DOM 中移除之前做一些清理工作,来解决内存泄露问题。为了做到这一点,我们会在 Vue 实例的数据对象中保留一个属性,并会使用 Choices API 中的 destroy() 方法将其清除。

<button v-if=“showChoices” @click=“hide”>Hide

<button v-if=“!showChoices” @click=“show”>Show

❤️ 谢谢支持

喜欢的话别忘了 关注、点赞哦~。

开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

前端校招面试题精编解析大全

},

},

}

在上述的示例中,我们可以用 hide() 方法在将选择框从 DOM 中移除之前做一些清理工作,来解决内存泄露问题。为了做到这一点,我们会在 Vue 实例的数据对象中保留一个属性,并会使用 Choices API 中的 destroy() 方法将其清除。

<button v-if=“showChoices” @click=“hide”>Hide

<button v-if=“!showChoices” @click=“show”>Show

❤️ 谢谢支持

喜欢的话别忘了 关注、点赞哦~。

开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

[外链图片转存中…(img-xJiB3IuY-1715723247180)]

  • 24
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值