当前位置: 首页 > news >正文

一七二、Vue3性能优化方式

Vue 3 的性能优化相较于 Vue 2 有了显著提升,利用新特性和改进方法可以更高效地构建和优化应用。以下是 Vue 3 的常见性能优化方法及示例。

1. 使用组合式 API (Composition API)

Vue 3 引入的组合式 API,通过逻辑拆分和复用来实现更高效的代码组织和性能优化。它可以减少组件内的依赖关系,避免不必要的状态更新和渲染。

import { ref, computed } from 'vue';export default {setup() {const count = ref(0);const doubleCount = computed(() => count.value * 2);function increment() {count.value++;}return { count, doubleCount, increment };}
};

使用 setup 函数可以清晰地定义响应式状态,避免类组件中频繁使用 this 的问题,也提升了代码的可读性和复用性。

2. 动态组件懒加载

Vue 3 可以利用动态组件的懒加载,将不必要的代码块按需加载,减少首屏加载时间。

<template><Suspense><template #default><AsyncComponent /></template><template #fallback><div>Loading...</div></template></Suspense>
</template><script>
import { defineAsyncComponent } from 'vue';export default {components: {AsyncComponent: defineAsyncComponent(() =>import('./AsyncComponent.vue'))}
};
</script>

在此示例中,AsyncComponent 会在首次渲染时进行懒加载。Suspensefallback 提供了加载时的占位内容,带来更好的用户体验。

3. 使用 Teleport 移除 DOM 元素嵌套

Teleport 可以将某些组件直接渲染到指定的 DOM 位置,而不是默认的组件层级结构中,减少了 DOM 的深层嵌套和性能开销,特别适合弹窗、对话框等需要在根节点渲染的场景。

<template><Teleport to="body"><div class="modal">This is a modal</div></Teleport>
</template>

通过将弹窗渲染到 body,减少了嵌套和 CSS 的复杂性,有利于浏览器快速渲染。

4. 使用 v-memo 进行缓存

Vue 3 提供了 v-memo 指令,通过缓存结果来减少重新渲染。例如在大量动态数据的列表中,v-memo 可以显著减少数据未变更时的渲染次数。

<template v-for="(item, index) in list" :key="item.id" v-memo="[item]"><div>{{ item.name }}</div>
</template>

这里使用了 v-memo 缓存 item,避免当 list 中的某一项没有变更时重复渲染整个列表,提升渲染效率。

5. ReactiveRef 的响应式性能

Vue 3 的 reactiveref API 基于 Proxy 实现,具备更高的性能。尽量在深度嵌套的对象中使用 reactive 来提升性能:

import { reactive, ref } from 'vue';const state = reactive({user: {name: 'John',age: 30}
});const count = ref(0);

reactiveref 提供更精细的响应式追踪,避免数据更新时触发不必要的依赖更新,从而减少渲染的开销。

6. 使用 defineComponent 优化组件定义

defineComponent 是 Vue 3 提供的辅助函数,通过在组件定义时启用类型推断,可以更好地在 TypeScript 中使用组件,从而在开发过程中提高性能和可维护性。

import { defineComponent, ref } from 'vue';export default defineComponent({setup() {const message = ref('Hello Vue 3');return { message };}
});

defineComponent 可以帮助 Vue 提前分析组件结构并优化渲染过程。

7. 避免过多的计算属性

Vue 3 的计算属性仍然是基于 getter/setter 实现的,虽然 Vue 会自动缓存计算结果,但在复杂的嵌套结构下,过多的计算属性会拖慢响应速度。可以考虑将某些计算属性转换为方法调用。

<template><div>{{ computedValue }}</div>
</template><script>
import { ref, computed } from 'vue';export default {setup() {const count = ref(1);// 优化:将简单计算转为方法,减少计算属性开销function calculateDouble() {return count.value * 2;}return { calculateDouble };}
};
</script>

将简单的计算提取为方法调用,有助于降低计算属性的依赖链,提高性能。

8. 使用异步 watchEffect

Vue 3 的 watchEffect 可以异步执行复杂的副作用,从而避免阻塞渲染。异步 watchEffect 特别适合需要访问外部 API 的副作用操作。

import { ref, watchEffect } from 'vue';const data = ref(null);watchEffect(async () => {const response = await fetch('https://api.example.com/data');data.value = await response.json();
});

通过异步 watchEffect,可以避免阻塞其他渲染操作,使页面更快响应用户的交互。

9. 虚拟滚动优化大数据渲染

在渲染大量列表数据时,可以使用虚拟滚动库(如 vue-virtual-scroll-list)优化滚动性能,只渲染当前可见的数据。

<template><virtual-list :size="50" :remain="10" :data-key="'id'" :data-sources="list"><template v-slot="{ item }"><div>{{ item.name }}</div></template></virtual-list>
</template><script>
import VirtualList from 'vue-virtual-scroll-list';export default {components: { VirtualList },data() {return {list: Array.from({ length: 1000 }, (_, i) => ({ id: i, name: `Item ${i}` }))};}
};
</script>

虚拟滚动只渲染当前可见的数据项,避免大量 DOM 元素导致的性能问题。

10. 使用 Tree-Shaking 和按需加载

Vue 3 通过支持 Tree-Shaking,自动去除未使用的代码。确保使用 Vue 3 的按需加载和相关组件库的 import,减少包体积。

import { createApp } from 'vue';
import Button from 'some-ui-library/Button';const app = createApp(App);
app.component('Button', Button);

按需加载不仅缩小了应用的打包体积,也减少了页面加载的资源开销。

总结

Vue 3 的优化方法围绕高效的响应式系统和异步渲染展开,通过组合式 API、按需加载、虚拟滚动和按需 Tree-Shaking 等技术手段,使 Vue 应用具备更好的性能表现。

http://www.lryc.cn/news/475996.html

相关文章:

  • 软件测试--BUG篇
  • Scikit-learn和Keras简介
  • python在word的页脚插入页码
  • Java面试题十四
  • yarn : 无法加载文件,未对文件 进行数字签名。无法在当前系统上运行该脚本。
  • Hadoop——HDFS
  • 计算机的一些基础知识
  • 学习RocketMQ(记录了个人艰难学习RocketMQ的笔记)
  • 【设计模式】策略模式定义及其实现代码示例
  • list与iterator的之间的区别,如何用斐波那契数列探索yield
  • 抖音店铺数据也就是抖店,如何使用小店数据集来挖掘价值?
  • KubeVirt 安装和配置 Windows虚拟机
  • CM API方式设置YARN队列资源
  • Mysql常用语法一篇文章速成
  • Intel nuc x15 重装系统步骤和注意事项(LAPKC71F、LAPKC71E、LAPKC51E)
  • Linux之实战命令59:iwlist应用实例(九十三)
  • 数据库_SQLite3
  • .Net Framework里演示怎么样使用StringBuilder、Math.Min和String.Format
  • Oracle创建存储过程,创建定时任务
  • <HarmonyOS第一课>应用/元服务上架的课后习题
  • 【Python】探索函数的奥秘:从基础到高级的深度解析(下)
  • ima.copilot:智慧因你而生
  • Vue-$el属性
  • LLC Power Switches and Resonant Tank 笔记
  • Python 如何在 Web 环境中使用 Matplotlib 进行数据可视化
  • C#-数组:一维数组、二维数组、交错数组
  • 动态规划应该如何学习?
  • 【力扣 + 牛客 | SQL题 | 每日4题】牛客SQL热题210,213,212,219
  • Qt 应用开发之 MVC 架构
  • python之字符串总结