前端核心知识: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

JSP 文件上传详解

JSP 文件上传详解 引言 在Web开发中,文件上传是一个常见的功能,它允许用户将文件从客户端发送到服务器。Java Server Pages(JSP)作为一种强大的服务器端技术,也支持文件上传功能。本文将详细讲解JSP文件上传的实现过程,包括技术原理、实现步骤和注意事项。 技术原理 JSP文件上传主要依赖于HTTP协议的multipart/form-data编码类型。这种编码类型允许表单中包含文件类型的输入字段。当用户提交表单时,浏览器会将表单数据以文件的形式发送到服务器。 服务器端使用Java的javax.servlet包中的HttpServletRequest和HttpServletResponse对象来接收这些文件。同时,javax.servlet包中的javax.servlet.http模块提供了Part接口,用于访问上传的文件内容。 实现步骤 以下是使用JSP实现文件上传的基本步骤: 1. 创建HTML表单 首先,我们需要创建一个HTML表单,其中包含一个文件类型的输入字段。以下是一个简单的示例: <form action="upload.jsp"

By Ne0inhk
Java外功精要(6)——Spring事务及其传播机制

Java外功精要(6)——Spring事务及其传播机制

1.概述 Spring事务管理是Spring框架中用于确保数据库操作 原子性、一致性、隔离性和持久性(ACID) 的核心机制。它通过声明式或编程式(本文略)方式管理事务,支持多种事务传播行为和隔离级别相较于编程式事务,声明式事务通过@Transactional注解实现事务管理,无需手动编写事务代码事务基本概念在全面解析MySQL(5)——“索引、事务、JDBC”三大核心一文中有介绍,本文不再赘述 2.@Transactional 作用:提供声明式事务管理。它简化了在应用程序中管理数据库事务的流程。开发者只需在方法或类上添加此注解,Spring框架就会自动处理事务的开启、提交和回滚,无需手动编写事务管理代码(如 begin、commit、rollback) 级别:类 + 方法作为类注解:为类中所有public方法添加注解作为方法注解:默认仅对public方法生效 @RequestMapping("/test")@RestController@Slf4jpublicclassTestController{privatefinalUserService userService;@A

By Ne0inhk
Java初识面向对象+类与对象+封装核心

Java初识面向对象+类与对象+封装核心

🏠个人主页:黎雁 🎬作者简介:C/C++/JAVA后端开发学习者 ❄️个人专栏:C语言、数据结构(C语言)、EasyX、JAVA、游戏、规划、程序人生 ✨ 从来绝巘须孤往,万里同尘即玉京 文章目录 * ✨Java面向对象精讲(一):初识面向对象+类与对象+封装核心|零基础吃透OOP思想 * 📌 文章摘要(248字) * 🕒 阅读时长:约12分钟 * ✅ 适用人群 & 阅读重点 * 📖 知识回顾(课前必看,快速衔接) * 一、初识面向对象 ☀️ 从生活到代码,彻底理解核心思想 * 1.1 什么是面向对象?(生活案例,通俗易懂) * 1.2 我们要学的两大核心内容 * 二、设计对象并使用 ✍️ 类与对象【核心重点,

By Ne0inhk
【JAVA 进阶】深入拆解SpringBoot自动配置:从原理到实战的完整指南

【JAVA 进阶】深入拆解SpringBoot自动配置:从原理到实战的完整指南

文章目录 * 前言 * 第一章 初识SpringBoot自动配置:什么是“约定优于配置” * 1.1 传统Spring配置的痛点 * 1.2 SpringBoot自动配置的核心价值 * 1.3 自动配置的核心特性 * 第二章 深入源码:自动配置的实现原理 * 2.1 自动配置的“入口”:@SpringBootApplication * 2.2 自动配置的“引擎”:@EnableAutoConfiguration * 2.2.1 自动配置包扫描:@AutoConfigurationPackage * 2.2.2 自动配置类加载:AutoConfigurationImportSelector * 步骤1:加载候选自动配置类 * 步骤2:筛选符合条件的自动配置类 * 步骤3:导入筛选后的自动配置类 * 2.3 自动配置的“开关”:条件注解 * 2.

By Ne0inhk