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

从社死边缘拯救我:用 AR 眼镜打造“亲戚称呼助手“

从社死边缘拯救我:用 AR 眼镜打造“亲戚称呼助手“

从社死边缘拯救我:用 AR 眼镜打造"亲戚称呼助手 一个真实的新年灾难 大年初二,我跟着新婚妻子回娘家。 刚进门,七大姑八大姨就围了上来。一位头发花白的阿姨笑盈盈地递过来一个红包,我脑子里嗡的一声——这到底是妻子的哪位亲戚?大姨?小姨?还是什么远房表姑? “小张啊,还认识我不?” 我支支吾吾半天,最后还是妻子打了圆场:“这是大姨,小时候还抱过你呢!” 那一刻,我看到了大姨眼里的失望。这种社死现场,相信很多人都经历过:春节期间,走亲访友是必修课,但那些一年见一次的亲戚,名字和称呼根本记不住。尤其是刚结婚的新人、不常回家的打工人,简直是"称呼灾难"高发人群。 回家后,我下定决心:明年春节,我绝不能再叫错人。 思路:为什么是 AR 眼镜? 解决方案无非几种: ● 记在手机备忘录:掏手机、解锁、

Techub News 專訪高鋒集團合夥人、Web3Labs行政總裁黃俊瑯:以資本與生態,賦能傳統企業Web3轉型

本次專訪聚焦高鋒集團如何透過資本投入與生態資源,助力傳統企業邁向Web3轉型。從近期戰略參與上市公司德祥地產的配股出發,高鋒集團合夥人、Web3Labs CEO黃俊瑯(Caspar)分享了集團的戰略思考、核心優勢、執行機制,以及對傳統企業轉型痛點的觀察與未來願景。這場對話展現了高鋒集團與Web3Labs在「實物資產代幣化」(RWA)等領域的創新實踐,以及他們致力成為傳統企業數字化轉型可靠夥伴的定位。 戰略投資德祥地產:搭建Web3與傳統實體經濟的橋樑 Techub News:Caspar您好。我們注意到高鋒集團近期戰略性參與了上市公司德祥地產的配股。這在市場看來頗為創新,能否請您談談這次投資背後的戰略思考? 黃俊瑯:這次對德祥地產的投資,對我們而言,遠超一次單純的財務投資。它是一個清晰的信號,也是我們戰略的關鍵落子。高鋒集團的核心使命之一,是搭建Web3前沿科技與傳統實體經濟之間的橋樑。德祥擁有紮實的房地產業務與實物資產,這正是探索「實物資產代幣化」(RWA)最具潛力的領域。我們這次參與,是協助其啟動轉型的第一步,未來將結合我們的專業生態,共同探索如何利用區塊鏈技術提升資產流

35道常见的前端vue面试题,零基础入门到精通,收藏这篇就够了

35道常见的前端vue面试题,零基础入门到精通,收藏这篇就够了

来源 | https://segmentfault.com/a/1190000021936876 今天这篇文章给大家分享一些常见的前端vue面试题。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 对于前端来说,尽管css、html、js是主要的基础知识,但是随着技术的不断发展,出现了很多优秀的mv*框架以及小程序框架。因此,对于前端开发者而言,需要对一些前端框架进行熟练掌握。这篇文章我们一起来聊一聊VUE及全家桶的常见面试问题。 1、请讲述下VUE的MVVM的理解? MVVM 是 Model-View-ViewModel的缩写,即将数据模型与数据表现层通过数据驱动进行分离,从而只需要关系数据模型的开发,而不需要考虑页面的表现,具体说来如下: Model代表数据模型:主要用于定义数据和操作的业务逻辑。 View代表页面展示组件(即dom展现形式):负责将数据模型转化成UI 展现出来。 ViewModel为model和view之间的桥梁:监听模型数据的改变和控制视图行为、处理用户交互。通过双向数据绑定把 View 层和 Model 层连接了起来,而View

Java Web 编程训练系统系统源码-SpringBoot2+Vue3+MyBatis-Plus+MySQL8.0【含文档】

Java Web 编程训练系统系统源码-SpringBoot2+Vue3+MyBatis-Plus+MySQL8.0【含文档】

摘要 随着信息技术的快速发展,互联网应用逐渐渗透到各行各业,教育领域也迎来了数字化转型的浪潮。传统的编程训练方式通常依赖于本地开发环境或简单的在线评测系统,难以满足现代教育对灵活性、交互性和数据驱动的需求。尤其是在高校计算机专业教学中,学生编程能力的培养需要更加系统化、智能化的平台支持。基于此背景,设计并实现一个高效、易用的Java Web编程训练系统具有重要意义。该系统旨在为学生提供在线编程练习、自动评测、学习进度跟踪等功能,同时为教师提供题目管理、成绩分析等教学辅助工具。关键词:Java Web、编程训练、在线评测、教学辅助、SpringBoot2。 本系统采用前后端分离架构,后端基于SpringBoot2框架搭建,结合MyBatis-Plus实现高效数据操作,MySQL8.0作为数据库存储系统数据。前端采用Vue3框架,利用其响应式特性和组件化开发优势,提升用户体验。系统核心功能包括用户权限管理、编程题目发布与提交、自动代码评测、学习数据统计分析等。通过集成第三方代码运行环境,系统能够支持多种编程语言的在线编译与执行。此外,系统还提供详细的错误反馈和性能分析报告,帮助学生快速