vue性能优化(响应数据&静态数据)

什么是响应式数据

在系统中会发生变化的数据,就是响应式数据,需要用ref或者reactive来定义,换而言之,用ref, reactive定义的数据就是响应式数据。

什么是静态数据

在系统中不会发生变化的就是静态数据,换而言之,静态数据不用ref,reactive包裹

性能优化方案

在系统中,不要把静态数据加上ref,reactive写成响应式数据。减少了 Vue 的响应式系统需要跟踪的依赖项数量,从而优化了性能。

举个栗子

js 复制代码
<template>
  <div>
    <h1>{{ staticData.title }}</h1>
    <p>{{ staticData.description }}</p>
    <p>Count: {{ count }}</p>
    <button @click="increment">Increment</button>
  </div>
</template>

<script>
import { ref } from 'vue';

export default {
  setup() {
    // 静态数据,不需要响应式
    const staticData = {
      title: 'Vue Performance Optimization',
      description: 'Learn how to optimize Vue performance with static and reactive data.'
    };

    // 响应式数据,使用 ref 创建
    const count = ref(0);

    const increment = () => {
      count.value++;
    };

    return {
      staticData,
      count,
      increment
    };
  }
};
</script>

详细说明:

  1. 静态数据

    • staticData 包括 titledescription,这些数据在组件初始化后不会改变。
    • 不需要使用 refreactive,因为它们不需要响应式特性。
    • 这样可以避免 Vue 对这些数据进行响应式处理,从而提高性能。
  2. 响应式数据

    • count 是一个需要响应式的数据,因为用户点击按钮时它会变化。
    • 使用 ref 将其包裹,使其成为响应式数据。
    • count 发生变化时,Vue 会自动更新 DOM。
  3. 性能优化

    • 通过只将需要响应的数据(如 count)包裹在 ref 中,避免了对静态数据(如 staticData)的不必要的响应式处理。
    • 这种方式减少了 Vue 的响应式系统需要跟踪的依赖项数量,从而优化了性能。

在 Vue 中,合理区分静态数据和响应式数据,使用 refreactive 只对需要响应的数据进行包装,可以有效避免不必要的性能开销。

相关推荐
wycode19 分钟前
Vue2实践(2)之用component做一个动态表单(一)
前端·javascript·vue.js
第七种黄昏21 分钟前
Vue3 中的 ref、模板引用和 defineExpose 详解
前端·javascript·vue.js
侑虎科技1 小时前
游戏AI行为决策——HTN(分层任务网络)
性能优化
pepedd8641 小时前
还在开发vue2老项目吗?本文带你梳理vue版本区别
前端·vue.js·trae
前端缘梦2 小时前
深入理解 Vue 中的虚拟 DOM:原理与实战价值
前端·vue.js·面试
HWL56792 小时前
pnpm(Performant npm)的安装
前端·vue.js·npm·node.js
柯南95272 小时前
Vue 3 reactive.ts 源码理解
vue.js
柯南95273 小时前
Vue 3 Ref 源码解析
vue.js
小高0073 小时前
面试官:npm run build 到底干了什么?从 package.json 到 dist 的 7 步拆解
前端·javascript·vue.js
代码的余温4 小时前
SQL性能优化全攻略
数据库·mysql·性能优化