这 10 个 Vue3 性能优化技巧很实用,但很多项目都没用上

news/2026/1/17 13:02:07/文章来源:https://www.cnblogs.com/smileZAZ/p/19495772

🧑‍💻 写在开头

点赞 + 收藏 === 学会🤣🤣🤣

今天来分享 10 个 Vue3 的性能优化技巧。

核心原则
减少不必要的响应式追踪
避免无谓的 DOM 操作
按需加载资源

咱也不要为了优化而优化!小项目用默认写法完全没问题,优化应在性能瓶颈出现后进行。

这些技巧不难,但都非常关键。 看完你会发现:原来 Vue3 还能这么写。


1. 使用 shallowReactive 替代 reactive

问题
reactive 会让对象里每一层都变得“敏感”——哪怕你只改了最里面的某个小字段,Vue 也会花力气去追踪它。数据一大,性能就变慢。

解决方案
对不需要深层响应的数据,使用 shallowReactive,只让最外层变成响应式的。

示例

import { shallowReactive } from 'vue';const data = shallowReactive({list: [],meta: { total: 0 }
});

适用场景
当你从后端拿到一大坨只读数据(比如表格列表、API 响应),且不会修改嵌套属性时。


2. 用 toRefs 解构响应式对象

问题
如果你直接从 reactive 对象里解构变量(如 const { name } = state),这个 name 就变成普通变量了,修改它不会触发页面更新。

解决方案
使用 toRefs 解构,保持每个属性的响应性。

示例

const state = reactive({ name: 'Vue', age: 3 });
const { name, age } = toRefs(state); // name 和 age 依然是响应式的!

好处
在模板中可以直接写 {{ name }},不用写 {{ state.name }},代码更清爽。


3. 优先使用 watchEffect 而非 watch

区别

  • watch:你要手动指定监听谁(比如 watch(count, ...))。
  • watchEffect:你只写逻辑,Vue 自动分析里面用了哪些响应式变量,并监听它们。

示例

watchEffect(() => {// Vue 自动发现 count.value 被用了 → 只要 count 变,这段就执行localStorage.setItem('count', count.value);
});

适合场景
保存用户输入到本地缓存、根据筛选条件自动请求数据、同步状态到 URL 等。


4. 利用 <Suspense> 优雅处理异步组件

问题
动态加载组件(如通过 import())时,页面可能白屏几秒,用户体验差。

解决方案
<Suspense> 包裹异步组件,显示 loading 提示。

示例

<Suspense><template #default><UserProfile /> <!-- 必须是异步组件 --></template><template #fallback><div>加载中,请稍候…</div></template>
</Suspense>

注意
仅适用于异步组件(即用 defineAsyncComponent() => import(...) 定义的组件)。


5. 使用 <Teleport> 解决模态框层级问题

问题
弹窗写在组件内部,可能被父级的 overflow: hiddenz-index 限制,导致显示不全或盖不住其他内容。

解决方案
<Teleport> 把组件“传送”到 <body> 底部,脱离当前 DOM 树。

示例

<Teleport to="body"><Modal v-if="show" />
</Teleport>

类比
就像你在客厅写了个气球,但它实际飘到了天空——不受房间天花板限制。

常用目标to="body" 是最常见用法。


6. 自定义指令封装高频操作(如复制)

问题
复制文本、防抖点击、自动聚焦……这些功能到处都要用,每次都写一堆代码很麻烦。

解决方案
写一个自定义指令,一次定义,处处使用。

示例

app.directive('copy', {mounted(el, binding) {el.addEventListener('click', () => {navigator.clipboard.writeText(binding.value);});}
});

使用:

<button v-copy="'要复制的内容'">点我复制</button>

好处:逻辑集中、复用性强、模板干净。


7. 用 Pinia 插件扩展 store 能力

问题
每个 store 都想加个“重置”功能?手动一个个写太重复。

解决方案
通过 Pinia 插件,一次性给所有 store 添加 $reset() 方法。

正确实现

pinia.use(({ store }) => {// 保存初始状态快照(深拷贝)const initialState = JSON.parse(JSON.stringify(store.$state));store.$reset = () => {store.$state = initialState;};
});

使用:

const userStore = useUserStore();
userStore.$reset(); // 恢复初始状态

适用场景:表单重置、清除缓存、统一日志等。

注意:不能直接用 store.$patch(store.$state),因为 $state 是当前状态,不是初始状态!


8. v-memo 优化大型列表渲染

问题
列表有上千项,哪怕只改了一行的状态,Vue 默认会重新比对整张表,浪费性能。

解决方案
v-memo 告诉 Vue:“只有这些值变了,才需要重新渲染这一行”。

示例

<li v-for="item in list" :key="item.id" v-memo="[item.id, item.status]">{{ item.name }} —— 状态:{{ item.status }}
</li>

注意事项

  • 适合内容稳定、更新频率低的大列表。
  • 不要和 <transition-group> 一起用(会失效)。
  • 高频变动的列表慎用,可能适得其反。

v-memo 是 Vue 3.2+ 的功能。


9. 虚拟滚动(Virtual Scrolling)

问题
渲染 10,000 条消息?浏览器直接卡死!

解决方案
只渲染“当前可见区域”的内容,滑动时动态替换,内存和性能都省下来。

推荐库(Vue 3 兼容)

  • vueuc(轻量、活跃维护)
  • vue-virtual-scroll-grid

安装 & 示例(以 vueuc 为例)

npm install vueuc

<script setup>
import { VirtualList } from 'vueuc';
</script><template><VirtualList :items="messages" :item-height="60" :bench="10"><template #default="{ item }"><MessageItem :msg="item" /></template></VirtualList>
</template>

类比:
就像微信聊天记录——你往上滑,旧消息才加载;不滑的时候,几千条其实没真画出来。


10. 路由与组件懒加载 + 图片优化

组件懒加载

原理:不是一打开网页就加载所有页面,而是“用到哪个才加载哪个”。

写法:

{ path: '/about', component: () => import('./views/About.vue') }

好处:首屏加载更快,节省流量和内存。

图片优化

  • 用 WebP 格式:比 JPG/PNG 小 30%~50%,清晰度不变(现代浏览器都支持)。
  • 图片懒加载:屏幕外的图先不加载,滑到附近再加载。
  • 关键图预加载:首页 Banner 图提前加载,避免白块。

简单懒加载(原生支持)

<img src="image.jpg" loading="lazy" alt="示例图" />

  

兼容性提示loading="lazy" 在 Chrome/Firefox/Edge 支持良好,但 Safari 15.4 以下和 IE 不支持。若需兼容旧环境,建议搭配 IntersectionObserver 或第三方库(如 lazysizes)。


总结

ScreenShot_2026-01-17_125239_004

如果对您有所帮助,欢迎您点个关注,我会定时更新技术文档,大家一起讨论学习,一起进步。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/1173512.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

2026年智慧校园专项资金申报政策解析:重点支持哪些方向?

✅作者简介&#xff1a;合肥自友科技 &#x1f4cc;核心产品&#xff1a;智慧校园平台(包括教工管理、学工管理、教务管理、考务管理、后勤管理、德育管理、资产管理、公寓管理、实习管理、就业管理、离校管理、科研平台、档案管理、学生平台等26个子平台) 。公司所有人员均有多…

国产化替代中,百度富文本编辑器支持哪些格式的截图粘贴?

企业网站后台管理系统富文本编辑器Word集成解决方案评估与实施报告 项目负责人&#xff1a;XXX 日期&#xff1a;2023-XX-XX 一、需求背景分析 当前集团企业网站后台管理系统存在以下核心需求&#xff1a; 需要实现Word内容完美粘贴&#xff08;保留所有样式和特殊元素&…

桌面大爷学Web(2)-AI SOLO模式实战:只动嘴不动手从零构建Vue地图页面

文章目录一、前言二、 项目背景三、交互开发流程第一次任务&#xff1a;项目初始化第二次任务&#xff1a;地图交互功能第三次任务&#xff1a;模式选择与量测功能第四次任务&#xff1a;数据库查询功能第五次任务&#xff1a;地名搜索功能最终任务 应用代码重构和添加注释重构…

【图像加密解密】基于matlab DNA编码混沌系统图像加密解密(数据丢失攻击测试、直方图分析、熵值计算、PSNR 峰值信噪比、像素相关性分析)【含Matlab源码 14961期】

&#x1f4a5;&#x1f4a5;&#x1f4a5;&#x1f4a5;&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;&#x1f49e;&#x1f49e;&#x1f49e;&#x1f49e;&#x1f49e;&#x1f49e;欢迎来到海神之光博客之家&#x1f49e;&#x1f49e;&#x1f49e;&#x1f49…

【图像加密解密】傅立叶变换和相位掩膜带相位掩模的图像加密解密【含Matlab源码 14963期】

&#x1f4a5;&#x1f4a5;&#x1f4a5;&#x1f4a5;&#x1f4a5;&#x1f4a5;&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;&#x1f49e;&#x1f49e;&#x1f49e;&#x1f49e;&#x1f49e;&#x1f49e;&#x1f49e;Matlab领域博客之家&#x1f49e;&…

Maven教程(Maven简介之构建工具)

1.1 依赖管理工具 管理规模庞大的 jar 包,需要专门工具 示例依赖:opentest4j-1.2.0.jar、mysql-connector-java、web.xml 1.2 构建工具 脱离 IDE 环境仍需构建:在服务器环境中必须通过命令行进行项目构建 支持版本控…

【图像加密解密】基于matlab分数阶傅立叶变换和曲线锯变换图像加密解密【含Matlab源码 14962期】

&#x1f4a5;&#x1f4a5;&#x1f4a5;&#x1f4a5;&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;&#x1f49e;&#x1f49e;&#x1f49e;&#x1f49e;&#x1f49e;&#x1f49e;欢迎来到海神之光博客之家&#x1f49e;&#x1f49e;&#x1f49e;&#x1f49…

05谓词逻辑等值演算及推理

05谓词逻辑等值演算及推理

t检验(T test),亦称Student‘s t检验,是统计学中常用的一种假设检验方法,广泛应用于定量资料的两组均数比较

下面内容摘录自《用R探索医药数据科学》专栏文章的部分内容&#xff08;原文5422字&#xff09;。 2篇3章6节&#xff1a;R中进行独立样本的t检验_r 独立样本t检验-CSDN博客 t检验&#xff08;T test&#xff09;&#xff0c;亦称Students t检验&#xff0c;是统计学中常用的一…

2026年目前比较好的智能仓库供应厂家推荐排行,全自动仓库/智能仓库/自动化立体仓库/立体仓储,智能仓库加工厂推荐榜单 - 品牌推荐师

随着制造业数字化转型加速,智能仓库已成为企业降本增效的核心基础设施。据第三方机构统计,2025年国内智能仓储市场规模突破800亿元,年复合增长率超18%。然而,市场碎片化特征显著,超60%企业面临供应商选择困难——…

看似 “捡漏” 的诱饵:地产经纪人的对比效应策略

为什么地产经纪人常常带客户看两栋差不多完全一样的房子&#xff0c;但其中一栋却比另一栋既便宜、环境又好&#xff1f;看似 “捡漏” 的诱饵&#xff1a;地产经纪人的对比效应策略地产经纪人带客户看 “差不多但更划算” 的房子&#xff0c;本质是利用行为经济学中的对比效应…

跨平台网页应用如何用vue实现文件夹上传?

前端老炮的20G文件夹上传大冒险&#xff08;附部分代码&#xff09; 各位前端同仁们&#xff0c;我是老张&#xff0c;一个在辽宁苦哈哈写代码的"前端民工"。最近接了个活&#xff0c;客户要求用原生JS实现20G文件夹上传下载&#xff0c;还要支持IE9&#xff01;这简…

【技术内幕】为什么你写的 Python 翻译脚本总是不好用?揭秘工业级 AI 图片翻译的“四步流水线”

Python 系统架构 计算机视觉 OCR AIGC 跨境电商摘要在跨境电商的自动化浪潮中&#xff0c;图片翻译&#xff08;Image Translation&#xff09; 是需求最旺盛的场景。许多开发者试图通过拼接开源库&#xff08;如 pytesseract, googletrans, Pillow&#xff09;来实现这一功能&…

ALLEGRO怎么给铜皮倒角

如果你想其中一个倒角

军工企业网页项目怎么实现文件夹上传功能?

大文件传输系统技术方案设计与实现&#xff08;第一人称专业报告&#xff09; 一、项目背景与需求分析 作为广西某软件公司前端工程师&#xff0c;近期负责一个关键项目的大文件传输模块开发。该项目需求具有以下特点&#xff1a; 支持20GB级大文件传输&#xff08;上传/下载…

【Python自动化】手机壳/T恤卖家的福音:如何用“主从克隆”技术瞬间搞定 100 个 SKU 变体的图片翻译?

Python 多变体运营 SKU管理 图像合成 跨境电商摘要在跨境电商&#xff08;如 Amazon Merch, Etsy, Casetify 模式&#xff09;中&#xff0c;多变体&#xff08;Multi-Variant&#xff09; 产品是管理的噩梦。一款手机壳可能有 50 种花色&#xff0c;一款 T 恤可能有 20 种底色…

2026年服务好的专卖店施工公司电话大盘点,靠谱企业全揭秘 - 工业品牌热点

在消费升级与品牌体验经济的浪潮下,专卖店作为品牌与消费者直接对话的线下橱窗,其空间设计与施工品质直接决定了品牌形象的传递效率与用户转化效果。面对市场上良莠不齐的专卖店施工与设计服务,如何找到既懂品牌调性…

《P1850 [NOIP 2016 提高组] 换教室》

题目背景NOIP2016 提高组 D1T3题目描述对于刚上大学的牛牛来说&#xff0c;他面临的第一个问题是如何根据实际情况申请合适的课程。在可以选择的课程中&#xff0c;有 2n 节课程安排在 n 个时间段上。在第 i&#xff08;1≤i≤n&#xff09;个时间段上&#xff0c;两节内容相同…

【Python视觉实战】文字压住产品纹理怎么办?揭秘 AI 如何在“网眼/毛绒”材质上实现无痕去字

Python AIGC 图像修复 Inpainting 计算机视觉 跨境电商摘要在跨境电商的素材处理中&#xff0c;最令美工崩溃的场景莫过于**“文字与产品纹理重叠”。当中文卖点直接印在运动鞋的透气网面、羽绒服的复杂的缝线、或是实木家具的纹理上时&#xff0c;传统的仿制图章工具几乎无法还…