前端核心知识:Vue 3 编程的 10 个实用技巧

在这里插入图片描述

文章目录

    • 1. **使用 `ref` 和 `reactive` 管理响应式数据**
      • 原理解析
      • 代码示例
      • 注意事项
    • 2. **组合式 API(Composition API)**
      • 原理解析
      • 代码示例
      • 优势
    • 3. **使用 `watch` 和 `watchEffect` 监听数据变化**
      • 原理解析
      • 代码示例
      • 注意事项
    • 4. **使用 `provide` 和 `inject` 实现跨组件通信**
      • 原理解析
      • 代码示例
      • 优势
    • 5. **使用 `Teleport` 实现组件挂载到任意位置**
      • 原理解析
      • 代码示例
      • 优势
    • 6. **使用 `Suspense` 处理异步组件加载**
      • 原理解析
      • 代码示例
      • 优势
    • 7. **使用 `v-model` 实现双向绑定**
      • 原理解析
      • 代码示例
      • 自定义组件 `CustomInput`
      • 优势
    • 8. **使用 `defineComponent` 增强 TypeScript 支持**
      • 原理解析
      • 代码示例
      • 优势
    • 9. **使用 `Fragment` 减少不必要的 DOM 元素**
      • 原理解析
      • 代码示例
      • 优势
    • 10. **使用 `Custom Directives` 自定义指令**
      • 原理解析
      • 代码示例
      • 使用示例
      • 优势
    • 总结

在这里插入图片描述

1. 使用 refreactive 管理响应式数据

在这里插入图片描述

原理解析

Vue 3 引入了 refreactive 两个核心 API 来管理响应式数据:

  • ref:用于创建基本类型(如字符串、数字)的响应式数据,返回一个包含 value 属性的对象。
  • reactive:用于创建复杂对象或数组的响应式数据,返回一个代理对象。

代码示例

import { ref, reactive } from 'vue';// 使用 ref 管理基本类型数据
const count = ref(0);
console.log(count.value); // 0// 使用 reactive 管理复杂对象
const state = reactive({name: 'Vue 3',version: '3.2.0',
});
console.log(state.name); // Vue 3

注意事项

  • 使用 ref 时,需要通过 .value 访问或修改数据。
  • reactive 只能用于对象或数组,不能用于基本类型。

2. 组合式 API(Composition API)

在这里插入图片描述

原理解析

组合式 API 是 Vue 3 的核心特性之一,它允许开发者将逻辑代码组织成可复用的函数,而不是依赖于选项式 API(如 datamethods 等)。通过 setup 函数,开发者可以更灵活地管理组件的状态和逻辑。

代码示例

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,};},
};

优势

  • 逻辑复用性更强。
  • 代码组织更清晰,尤其是复杂组件。

3. 使用 watchwatchEffect 监听数据变化

在这里插入图片描述

原理解析

  • watch:用于监听特定响应式数据的变化,支持深度监听和懒执行。
  • watchEffect:自动追踪其依赖的响应式数据,并在依赖变化时立即执行。

代码示例

import { ref, watch, watchEffect } from 'vue';const count = ref(0);// 使用 watch 监听 count 的变化
watch(count, (newValue, oldValue) => {console.log(`count changed from ${oldValue} to ${newValue}`);
});// 使用 watchEffect 自动追踪依赖
watchEffect(() => {console.log(`count is now ${count.value}`);
});

注意事项

  • watch 更适合精确控制监听逻辑。
  • watchEffect 适合不需要明确指定依赖的场景。

4. 使用 provideinject 实现跨组件通信

原理解析

provideinject 是 Vue 3 中实现跨组件通信的 API,特别适合在深层嵌套组件中传递数据。

代码示例

// 父组件
import { provide, ref } from 'vue';export default {setup() {const message = ref('Hello from parent');provide('message', message);},
};// 子组件
import { inject } from 'vue';export default {setup() {const message = inject('message');return { message };},
};

优势

  • 避免逐层传递 props 的繁琐。
  • 适合全局状态管理(如主题、用户信息等)。

在这里插入图片描述

5. 使用 Teleport 实现组件挂载到任意位置

原理解析

Teleport 是 Vue 3 新增的特性,允许将组件的内容渲染到 DOM 中的任意位置,常用于模态框、通知等场景。

代码示例

<template><button @click="showModal = true">Open Modal</button><Teleport to="body"><div v-if="showModal" class="modal"><p>This is a modal!</p><button @click="showModal = false">Close</button></div></Teleport>
</template><script>
import { ref } from 'vue';export default {setup() {const showModal = ref(false);return { showModal };},
};
</script>

优势

  • 解决组件层级和样式隔离问题。
  • 提升用户体验。

6. 使用 Suspense 处理异步组件加载

原理解析

Suspense 是 Vue 3 中用于处理异步组件加载的特性,可以在组件加载完成前显示占位内容。

代码示例

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

优势

  • 提升用户体验,避免页面空白。
  • 简化异步组件加载逻辑。

在这里插入图片描述

7. 使用 v-model 实现双向绑定

原理解析

Vue 3 对 v-model 进行了改进,支持多个 v-model 绑定,并可以通过 modelValueupdate:modelValue 自定义绑定逻辑。

代码示例

<template><CustomInput v-model:firstName="firstName" v-model:lastName="lastName" />
</template><script>
import { ref } from 'vue';export default {setup() {const firstName = ref('John');const lastName = ref('Doe');return { firstName, lastName };},
};
</script>

自定义组件 CustomInput

<template><input :value="firstName" @input="$emit('update:firstName', $event.target.value)" /><input :value="lastName" @input="$emit('update:lastName', $event.target.value)" />
</template><script>
export default {props: ['firstName', 'lastName'],
};
</script>

优势

  • 支持多个 v-model 绑定。
  • 更灵活的双向绑定实现。

8. 使用 defineComponent 增强 TypeScript 支持

在这里插入图片描述

原理解析

defineComponent 是 Vue 3 中用于增强 TypeScript 支持的 API,可以提供更好的类型推断和代码提示。

代码示例

import { defineComponent, ref } from 'vue';export default defineComponent({setup() {const count = ref(0);return { count };},
});

优势

  • 提升 TypeScript 开发体验。
  • 更好的类型安全和代码提示。

9. 使用 Fragment 减少不必要的 DOM 元素

原理解析

Vue 3 支持多根节点组件(Fragment),可以减少不必要的 DOM 元素,提升渲染性能。

代码示例

<template><header>Header</header><main>Main Content</main><footer>Footer</footer>
</template>

优势

  • 减少不必要的 DOM 层级。
  • 提升渲染性能。

10. 使用 Custom Directives 自定义指令

在这里插入图片描述

原理解析

Vue 3 允许开发者自定义指令,用于直接操作 DOM 元素。

代码示例

import { directive } from 'vue';const vFocus = {mounted(el) {el.focus();},
};export default {directives: {focus: vFocus,},
};

使用示例

<input v-focus />

优势

  • 提供更灵活的 DOM 操作能力。
  • 适合实现特定功能(如自动聚焦、拖拽等)。

总结

本文详细介绍了 Vue 3 编程中的 10 个实用技巧,涵盖了响应式数据管理、组合式 API、跨组件通信、异步组件加载等多个方面。通过掌握这些技巧,开发者可以更高效地构建现代化的 Vue 应用,提升代码质量和开发体验。希望本文能为您的 Vue 3 开发之旅提供帮助!

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

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

相关文章

【Web API系列】XMLHttpRequest API和Fetch API深入理解与应用指南

前言 在现代Web开发中&#xff0c;客户端与服务器之间的异步通信是构建动态应用的核心能力。无论是传统的AJAX技术&#xff08;基于XMLHttpRequest&#xff09;还是现代的Fetch API&#xff0c;它们都为实现这一目标提供了关键支持。本文将从底层原理、核心功能、代码实践到实…

[特殊字符] Spring Boot 日志系统入门博客大纲(适合初学者)

一、前言 &#x1f4cc; 为什么日志在项目中如此重要&#xff1f; 在开发和维护一个后端系统时&#xff0c;日志就像程序运行时的“黑匣子”&#xff0c;帮我们记录系统的各种行为和异常。一份良好的日志&#xff0c;不仅能帮助我们快速定位问题&#xff0c;还能在以下场景中…

IP协议之IP,ICMP协议

1.因特网中的主要协议是TCP/IP&#xff0c;Interneet协议也叫TCP/IP协议簇 2.ip地址用点分十进制表示&#xff0c;由32位的二进制表示&#xff0c;两部分组成&#xff1a;网络标识主机标识 3.IP地址分类; A:0.0.0.0-127.255.255.255 B&#xff1a;128.0.0.0-191.255.255.25…

GPIO_ReadInputData和GPIO_ReadInputDataBit区别

目录 1、GPIO_ReadInputData: 2、GPIO_ReadInputDataBit: 总结 GPIO_ReadInputData 和 GPIO_ReadInputDataBit 是两个函数&#xff0c;通常用于读取微控制器GPIO&#xff08;通用输入输出&#xff09;引脚的输入状态&#xff0c;特别是在STM32系列微控制器中。它们之间的主要…

洛古B4158 [BCSP-X 2024 12 月小学高年级组] 质数补全(线性筛/dfs)

B4158 [BCSP-X 2024 12 月小学高年级组] 质数补全 - 洛谷 思路1:线性筛,字符串匹配,枚举 质数筛选 要解决这个问题&#xff0c;首先得找出指定范围内&#xff08;这里是 1 到 10000000&#xff09;的所有质数。常用的质数筛选算法有埃拉托斯特尼筛法&#xff08;埃氏筛&#…

一周学会Pandas2 Python数据处理与分析-Pandas2读取Excel

锋哥原创的Pandas2 Python数据处理与分析 视频教程&#xff1a; 2025版 Pandas2 Python数据处理与分析 视频教程(无废话版) 玩命更新中~_哔哩哔哩_bilibili Excel格式文件是办公使用和处理最多的文件格式之一&#xff0c;相比CSV文件&#xff0c;Excel是有样式的。Pandas2提…

NVIDIA H100 vs A100:新一代GPU架构性能对比分析

一、核心架构演进对比 ‌Ampere架构&#xff08;A100&#xff09;‌采用台积电7nm工艺&#xff0c;集成540亿晶体管&#xff0c;配备6,912个CUDA核心和432个第三代Tensor Core&#xff0c;支持FP16、TF32和INT8精度计算。其显存子系统采用HBM2e技术&#xff0c;80GB版本带宽可…

保护PCBA的不同方法:喷三防漆 vs 镀膜

PCBA&#xff08;印刷电路板组件&#xff09;的防护工艺中&#xff0c;喷三防漆和镀膜&#xff08;如Parylene气相沉积&#xff09;是两种常见技 术。它们在防护目的上类似&#xff0c;但在具体实现方式和应用场景上有显著差异。以下从外观、工艺、性 能、物理性质和成本五个…

VitePress 项目部署 cloudflare page 提示 npm run build 错误

构建的错误信息如下&#xff1a; 09:52:57.975 ➤ YN0000: Done with warnings in 3s 120ms 09:52:58.072 Executing user command: npm run build 09:52:58.817 npm ERR! Missing script: "build" 09:52:58.818 npm ERR! 09:52:58.818 npm ERR! To see a list of …

C++学习之ORACLE③

1.集合运算符 查询部门号是10和20的员工信息&#xff1a; &#xff1f;思考有几种方式解决该问题 &#xff1f; SQL> select * from emp where deptno in(10, 20) SQL> select * from emp where deptno10 or deptno20 集合运算&#xff1a; Select * from emp …

人工智能之数学基础:复矩阵

本文重点 复矩阵是线性代数中以复数为元素的矩阵,是实矩阵在复数域上的自然推广。与实矩阵相比,复矩阵在数学性质、运算规则和应用场景上具有独特性,尤其在量子力学、信号处理、控制理论等领域发挥关键作用。 复矩阵的定义与表示 定义:复矩阵指的是元素含有复数的矩阵。…

华清远见成都中心嵌入式学习总结

一、Linux 基础入门 课程首先介绍了 Linux 系统的六大特性&#xff0c;包括开源、免费、可裁剪等核心优势。重点讲解了文件系统结构&#xff0c;强调根目录&#xff08;/&#xff09;作为唯一入口的树状结构。通过实操学习了 pwd、ls、cd 等基础命令&#xff0c;掌握了绝对路径…

linux安装ollama

俩种方式都可 一、linux通过docker安装ollama镜像 1.下载安装ollama镜像 # 安装 Docker sudo yum install docker sudo systemctl start docker#docker查看所有容器 docker ps -a # 查看所有容器# docker查看指定容器 docker ps -a |grep ollama# 创建模型存储目录&#xff…

Redis 学习目标

&#x1f3af; Redis 学习目标&#xff08;开发者视角&#xff09; ✅ 一、学习完成后能掌握的核心能力&#xff1a; 分类具体内容&#x1f4e6; 基础能力熟练掌握 Redis 五大数据结构&#xff08;String、List、Hash、Set、ZSet&#xff09;&#xff0c;会用也会选对场景&am…

gerrit配置及使用git-lfs

gerrit服务器端配置 下载git-lfs插件 登录Dashboard [Jenkins] (gerritforge.com)&#xff0c;下载对应版本的插件 配置gerrit 将下载的lfs.jar插件放到${GERRIT_SITE}/plugins/下面为所有仓库启用git-lfs 此步骤需要修改 All-projects 仓库配置&#xff0c;步骤如下 1、克隆仓…

深入理解 Linux PATH 环境变量:配置与优化!!!

深入理解 Linux PATH 环境变量&#xff1a;配置与优化 &#x1f680; 欢迎来到 Linux 环境变量的奇妙世界&#xff01;今天我们来聊聊那个让命令行如鱼得水的幕后英雄——PATH 环境变量&#xff01;&#x1f60e; 通过这篇博客&#xff0c;你将学会如何配置它、优化它&#xff…

如何在AMD MI300X 服务器上部署 DeepSeek R1模型?

DeepSeek-R1凭借其深度推理能力备受关注&#xff0c;在语言模型性能基准测试中可与顶级闭源模型匹敌。 AMD Instinct MI300X GPU可在单节点上高效运行新发布的DeepSeek-R1和V3模型。 用户通过SGLang优化&#xff0c;将MI300X的性能提升至初始版本的4倍&#xff0c;且更多优化将…

简化DB操作:Golang 通用仓库模式

介绍 本代码包提供一个用于数据库操作的通用仓库 (GenericRepository)&#xff0c;利用 Golang 和 GORM (Go ORM) 实现。该仓库设计用于简化数据库的 CRUD (创建、读取、更新、删除) 操作&#xff0c;支持批处理、冲突处理、分页查询等高级功能。 主要功能 创建记录 (Create…

JavaWeb 课堂笔记 —— 08 请求响应

本系列为笔者学习JavaWeb的课堂笔记&#xff0c;视频资源为B站黑马程序员出品的《黑马程序员JavaWeb开发教程&#xff0c;实现javaweb企业开发全流程&#xff08;涵盖SpringMyBatisSpringMVCSpringBoot等&#xff09;》&#xff0c;章节分布参考视频教程&#xff0c;为同样学习…

双引擎驱动:解密音视频体验的QoS技术底座与QoE感官革命

QoS 定义&#xff1a;QoS&#xff08;Quality of Service&#xff0c;服务质量&#xff09;衡量音视频传输技术层面的性能表现&#xff0c;聚焦网络传输和系统处理能力&#xff0c;通过客观指标量化服务质量。核心指标 码率/带宽&#xff1a;数据传输速率上限&#xff0c;直接…