前端会造成内存泄漏的操作有哪些?页面卡住的原因

如果你发现前端页面卡住了,打开开发者工具也很卡,刷新页面也无效、或者关闭 tab页也很费劲,多半是有内存泄漏。

内存泄漏其实就是浏览器的内存被占用很多,导致页面奔溃。

以下是一些常见的引起内存泄漏的操作:

  1. 未正确解绑事件处理程序:

    • 如果在DOM元素上添加了事件监听器,但是在元素被移除之前没有被正确移除,就可能导致内存泄漏。确保使用 removeEventListener 来移除事件监听器。
  2. 定时器未清理:

    • 使用 setIntervalsetTimeout 创建定时器时,如果没有使用 clearIntervalclearTimeout 取消定时器,可能会导致内存泄漏。
  3. 闭包:

    • 在 JavaScript 中,闭包可能导致内存泄漏。当函数内部引用了外部函数的变量,并且该函数在外部函数执行后仍然存在,就会导致引用的变量无法被垃圾回收。
  4. 未释放资源:

    • 例如,使用 XMLHttpRequest 发送请求时,如果没有正确处理和释放资源,可能会导致内存泄漏。确保在请求完成后正确关闭或释放资源。
  5. DOM 元素引用:

    • 在 JavaScript 中引用了 DOM 元素,但在页面生命周期结束前没有释放这些引用。在单页应用(SPA)中,注意在组件销毁时释放对 DOM 元素的引用。
  6. 循环引用:

    • 如果两个或多个对象相互引用,而且没有被垃圾回收机制检测到,就可能导致内存泄漏。这是一种常见的情况,尤其是在使用缓存或数据结构时。
  7. 大量数据未清理:

    • 在处理大量数据时,确保及时清理不再需要的数据,以防止长时间占用内存。
  8. 使用缓存不当:

    • 如果不适当地使用缓存,可能导致缓存的数据一直存在于内存中,即使不再需要。需要定期清理缓存或使用一些策略来确保合理使用缓存。
  9. do / while 死循环

相关推荐
weixin_471383032 小时前
Taro-03-页面生命周期
前端·javascript·taro
张拭心2 小时前
Android 17 新特性:MessageQueue 无锁实现
android·前端
Asize2 小时前
数组数据结构底层:从灵活到陷阱
前端·javascript·算法
十九画生2 小时前
Ajax 入门:用 XHR 理解前后端异步请求
前端·javascript·后端
yingyima2 小时前
Python re 模块速查:从实战对比中掌握正则表达式
前端
放下华子我只抽RuiKe53 小时前
FastAPI 全栈后端(三):数据库与 ORM
前端·数据库·react.js·oracle·性能优化·前端框架·fastapi
梵得儿SHI4 小时前
Vue 项目实战与性能优化全攻略:从代码、渲染到首屏,一站式解决卡顿慢加载
前端·vue.js·性能优化·vite·前端面试·前端优化·首屏优化
ShyanZh4 小时前
【skill】HTML PPT Skill:用 Claude Code 一句话生成专业演示文稿
前端·ai·html·powerpoint·skill
AI视觉网奇4 小时前
three教学 3d资产拼接源代码
前端·css·css3
程序猿阿伟5 小时前
《Chrome标签组搭建多任务高效浏览指南》
前端·chrome