Vue3 实用技巧

跨层级传值:provideinject

在深层嵌套组件中,避免通过 props 逐层传递数据,使用 provide/inject 实现"直通式"数据共享:

js 复制代码
// 父组件
import { provide } from 'vue'; 
export default { 
    setup() { provide('theme', 'dark'); } 
}; 
// 子组件(任意层级)
import { inject } from 'vue';
export default { 
    setup() { 
        const theme = inject('theme'); // ✅ 获取父组件提供的值 } 
    };

组件传送门:Teleport

解决弹窗、下拉菜单等组件被父级样式覆盖的问题,通过 Teleport 将组件渲染到指定 DOM 节点(如 body):

xml 复制代码
<template>
    <button @click="showModal = true">打开弹窗</button> 
    <Teleport to="body">
        <div v-if="showModal" class="modal">
            <h3>重要通知</h3>
            <p>内容不受父级样式限制</p>
        </div> 
    </Teleport>
</template>

优势:彻底摆脱 DOM 层级嵌套限制,简化样式管理。

优化

列表渲染优化:v-memo

对长列表或动态表格,使用 v-memo 缓存渲染结果,仅当依赖项变化时重新渲染:

css 复制代码
<ul> 
    <li v-for="item in list" :key="item.id" v-memo="[item.id, item.status]">
        {{ item.name }} - {{ item.status }}
    </li>
</ul>

效果:减少无效更新,提升滚动流畅度。

虚拟滚动:vue-virtual-scroller

对于超长列表(如 1000+ 条数据),使用虚拟滚动库仅渲染可视区域内的元素,大幅降低 DOM 节点数:

html 复制代码
<template>
    <VirtualScroller :items="list" :item-size="50">
        <template v-slot="{ item }">
            <div>{{ item.name }}</div>
        </template>
    </VirtualScroller>
</template>

性能提升:从渲染 1000 个 DOM 节点降至渲染 10-20 个。

列表渲染 key 选择策略

  • 使用 index 作为 key:仅适用于无状态、不增删的列表(如分页展示)。
  • 使用唯一 id 作为 key:适用于大多数场景,确保精准更新。
  • 动态生成 key :当数据无唯一标识时,可使用 Symbol()uuid
js 复制代码
const list = ref([ 
    { id: Symbol(), name: '项目A' }, 
    { id: Symbol(), name: '项目B' } 
]);
相关推荐
踩着两条虫31 分钟前
VTJ.PRO 核心架构全公开!从设计稿到代码,揭秘AI智能体如何“听懂人话”
前端·vue.js·ai编程
蓝冰凌2 小时前
Vue 3 中 defineExpose 的行为【defineExpose暴露ref变量】详解:自动解包、响应性与实际使用
前端·javascript·vue.js
奔跑的呱呱牛3 小时前
generate-route-vue基于文件系统的 Vue Router 动态路由生成工具
前端·javascript·vue.js
sp42a3 小时前
在 NativeScript-Vue 中实现流畅的共享元素转场动画
vue.js·nativescript·app 开发
还是大剑师兰特4 小时前
Vue3 中 computed(计算属性)完整使用指南
前端·javascript·vue.js
孜孜不倦不忘初心5 小时前
Ant Design Vue 表格组件空数据统一处理 踩坑
前端·vue.js·ant design
csdn_aspnet5 小时前
查看 vite 与 vue 版本
javascript·vue.js
于先生吖5 小时前
SpringBoot+Vue 前后端分离短剧漫剧系统开发实战
vue.js·spring boot·后端
毕设源码-赖学姐6 小时前
【开题答辩全过程】以 基于VUE的环保网站设计为例,包含答辩的问题和答案
前端·javascript·vue.js