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

前端核心知识:Vue 3 编程的 10 个实用技巧
在这里插入图片描述

文章目录

在这里插入图片描述

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';exportdefault{setup(){const count =ref(0);const doubleCount =computed(()=> count.value *2);functionincrement(){ 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';exportdefault{setup(){const message =ref('Hello from parent');provide('message', message);},};// 子组件import{ inject }from'vue';exportdefault{setup(){const message =inject('message');return{ message };},};

优势

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

在这里插入图片描述

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

原理解析

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

代码示例

<template><button@click="showModal = true">Open Modal</button><Teleportto="body"><divv-if="showModal"class="modal"><p>This is a modal!</p><button@click="showModal = false">Close</button></div></Teleport></template><script>import{ ref }from'vue';exportdefault{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'));exportdefault{components:{ AsyncComponent,},};</script>

优势

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

在这里插入图片描述

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

原理解析

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

代码示例

<template><CustomInputv-model:firstName="firstName"v-model:lastName="lastName"/></template><script>import{ ref }from'vue';exportdefault{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>exportdefault{props:['firstName','lastName'],};</script>

优势

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

8. 使用 defineComponent 增强 TypeScript 支持

在这里插入图片描述

原理解析

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

代码示例

import{ defineComponent, ref }from'vue';exportdefaultdefineComponent({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();},};exportdefault{directives:{focus: vFocus,},};

使用示例

<inputv-focus/>

优势

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

总结

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

Read more

【AIGC】冷启动数据与多阶段训练在 DeepSeek 中的作用

【AIGC】冷启动数据与多阶段训练在 DeepSeek 中的作用

博客主页: [小ᶻ☡꙳ᵃⁱᵍᶜ꙳]本文专栏: AIGC |ChatGPT 文章目录 * 💯前言 * 💯冷启动数据的作用 * 冷启动数据设计 * 💯多阶段训练的作用 * 阶段 1:冷启动微调 * 阶段 2:推理导向强化学习(RL) * 阶段 3:拒绝采样与监督微调(SFT) * 阶段 4:多场景强化学习 * 💯代码示例:冷启动数据与多阶段训练的实现 * 1. 冷启动微调阶段 * 作用与应用: * 2. 推理导向的强化学习阶段 * 作用与应用: * 3. 拒绝采样与监督微调阶段 * 作用与应用: * 4. 多场景强化学习 * 作用与应用: * 总体流程 * DeepSeek 中的应用 * 💯总结 💯前言 在人工智能领域,深度学习模型的训练和优化往往需要大量的标注数据和计算资源。然而,面对复杂任务时,即使是最先进的技术和大量的训练数据也未必能够保证模型的最优表现。DeepSeek

GPU PRO 4 - 5.1 An Aspect-Based Engine Architecture 笔记

本笔记仅为个人的理解,如果有误欢迎指出 An Aspect-Based Engine Architecture 一种基于方面的引擎架构         不是很明白为什么GPU的书籍会有游戏引擎架构的文章。         这里Aspect在文章中的意义更像是表述一个功能模块,在Java中有将Aspect翻译成切面,但是Java切面主要是横向的代码注入,与本文的概念不相符。 大多数系统架构都会考虑将各个功能封装成模块或者组件,在面向对象编程的思想下,这个封装是基于对象去实现的,本文则描述了一种在引擎层面的封装功能的架构思想,封装后的产物被称为Aspect,每一个Aspect负责提供一些功能子集,并通过一个通用的接口与引擎核心通信。 引擎核心:         引擎核心的功能是保存游戏或者仿真时的数据结构以及相关状态,功能Aspect将会与这些数据进行交互。一般来说引擎核心会定义一些接口,外部的Aspect则通过接口访问当前的游戏数据                  用MVC架构的角度去理解的话引擎核心相当于M层,而各个Aspect则相当于C层。

基于FPGA的工业ALU模块构建:完整示例

基于FPGA的工业ALU模块构建:从原理到实战 在现代工业自动化系统中,实时性、可靠性和确定性是决定控制性能的核心指标。随着智能制造和边缘计算的发展,传统的通用处理器架构逐渐暴露出中断延迟高、流水线不可控、资源争抢等问题。而 FPGA(现场可编程门阵列) 凭借其并行处理能力与硬件级可定制特性,正成为解决这些痛点的关键技术路径。 本文将带你深入一个真实可用的工程场景——如何在FPGA上构建一个 工业级算术逻辑单元(ALU) 。我们将不走马观花地罗列概念,而是像一位嵌入式系统工程师那样,从需求出发,一步步拆解设计思路,手把手实现Verilog代码,并结合典型工业应用说明其价值所在。 为什么要在FPGA里“造”一个ALU? 你可能会问:CPU里不是已经有ALU了吗?为什么还要自己实现? 答案藏在“工业”两个字背后的需求中: * 硬实时响应 :电机控制环路要求微秒甚至纳秒级响应,软件调度无法满足。 * 多通道同步处理 :六轴机器人需要同时对多个传感器数据做差值、比较、累加。 * 抗干扰能力强 :无操作系统介入,避免任务抢占或内存泄漏导致失控。 * 算法固化为硬件 :关键运

YUXIANGROS实战:搭建智能仓储机器人系统

快速体验 1. 打开 InsCode(快马)平台 https://www.inscode.net 2. 输入框内输入如下内容: 开发一个仓储物流机器人系统,功能包括:1) 使用YOLOv5进行物品识别 2) 基于A*算法的路径规划 3) 货架二维码识别 4) 与WMS系统REST API对接。要求生成完整的ROS节点结构,包含自定义消息类型,并输出Gazebo仿真环境配置文件。 1. 点击'项目生成'按钮,等待项目生成完整后预览效果 最近在做一个仓储物流机器人的项目,正好用到了YUXIANGROS这个框架,感觉特别适合快速开发这类工业场景的机器人应用。分享一下我的实战经验,希望能帮到有类似需求的朋友。 1. 系统架构设计 整个系统采用模块化设计,主要分为感知、决策、执行三个层次。感知层负责环境信息采集,决策层处理业务逻辑,执行层控制机器人运动。这种分层结构让系统维护和扩展变得很方便。 2.