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' } 
]);
相关推荐
吹牛不交税2 小时前
admin.net-v2 框架使用笔记-netcore8.0/10.0版
vue.js·.netcore
MZ_ZXD0014 小时前
springboot旅游信息管理系统-计算机毕业设计源码21675
java·c++·vue.js·spring boot·python·django·php
_codemonster5 小时前
Vue的三种使用方式对比
前端·javascript·vue.js
wqq63108558 小时前
Python基于Vue的实验室管理系统 django flask pycharm
vue.js·python·django
Deng9452013148 小时前
Vue + Flask 前后端分离项目实战:从零搭建一个完整博客系统
前端·vue.js·flask
Hello.Reader8 小时前
Flink 文件系统通用配置默认文件系统与连接数限制实战
vue.js·flink·npm
EchoEcho10 小时前
深入理解 Vue.js 渲染机制:从声明式到虚拟 DOM 的完整实现
vue.js
C澒10 小时前
Vue 项目渐进式迁移 React:组件库接入与跨框架协同技术方案
前端·vue.js·react.js·架构·系统架构
发现一只大呆瓜12 小时前
虚拟列表:从定高到动态高度的 Vue 3 & React 满分实现
前端·vue.js·react.js
鱼毓屿御12 小时前
如何给用户添加权限
前端·javascript·vue.js