优化使用img标签加载svg大图导致的内存开销

问题背景

最近在排查系统内存泄漏问题时,发现某个页面的内存占用颇高(500M+),且访问过这个页面后,后续进入的页面的内存开销也会增加大约400M左右,怀疑存在内存泄漏问题

排查记录

未进入目标页面前的内存数据 进入目标页面后的内存数据 反复进入目标页面,发现内存数据始终稳定在 520M ~ 540M 左右,录制内存快照 发现占用最高的是 svg 相关节点,分析页面代码,发现业务上使用img标签加载了一张svg格式的图片,而这张图片高达 18M 浏览器使用img加载svg资源,是需要解析的,而18M左右的svg资源解析消耗的内存高达400M左右,而且这部分资源消耗不会随着img节点的销毁而释放。

结合业务场景,该页面的访问是一个相对低频的操作,用户一旦访问过该页面,内存可能在用户关闭页面前持续高位,导致页面卡顿、甚至浏览器崩溃(尤其是低配设备或移动端),因此需要手动干预这部分内存的回收

解决方案

可以手动在组件销毁阶段将img.src属性置为空,浏览器就会释放svg解析消耗的这部分资源

javascript 复制代码
<template>
   <img
    ref="imageRef"
    :src="imageUrl"
    :alt="altText"
    class="large-image__img"
    @load="handleImageLoad"
    @error="handleImageError"
    :style="{ maxWidth, maxHeight }"
  />
</template>
<scritp setup lang="ts">
import { onBeforeUnmount, useTemplateRef } from 'vue';

const imageRef = useTemplateRef<HTMLImageElement>('imageRef');

onBeforeUnmount(() => {
  if (imageRef.value) {
    imageRef.value.src = '';
  }
});

</script>

后续的思考

浏览器对svg解析资源的缓存可能是在某些场景下的一种优化手段,但如果加载的svg较大用户访问较低频 ,还是用完就销毁为好。

相关推荐
RealizeInnerSelf丶5 分钟前
Web 网页如何唤起本地 Windows 应用并传递参数(含 Electron 自动注册 + 手动配置指南)
前端·windows
IT_陈寒13 分钟前
Redis 性能优化实战:5个被低估的配置项让我节省了40%内存成本
前端·人工智能·后端
chilavert31814 分钟前
技术演进中的开发沉思-261 Ajax:动画优化
前端·javascript·ajax
尘心cx17 分钟前
前端-APIs-day3
开发语言·前端·javascript
烂不烂问厨房31 分钟前
前端自适应布局之等比例缩放
开发语言·前端·javascript
kong790692841 分钟前
环境搭建-运行前端工程
前端
CodeLinghu44 分钟前
提示词链模式:一种利用LLM大语言模型处理复杂任务的强大范式
前端·人工智能·语言模型
J2虾虾1 小时前
关于Ant Design Vue
前端·javascript·vue.js
程序员笨鸟1 小时前
[特殊字符] React 高频 useEffect 导致页面崩溃的真实案例:从根因排查到彻底优化
前端·javascript·学习·react.js·面试·前端框架
Highcharts.js1 小时前
从旧版到新版:Highcharts for React 迁移全攻略 + 开发者必知的 5 大坑
前端·react.js·前端框架·编辑器·highcharts