【Vue3】前端Vue3最常用的 20 道面试题总结(含详细代码解析)

【Vue3】前端Vue3最常用的 20 道面试题总结(含详细代码解析)

以下是老曹关于 Vue 3 最常用的 20 道面试题总结,涵盖 Vue 3 的核心特性如 Composition API、响应式系统(ref / reactive)、生命周期钩子、组件通信、Teleport、Suspense、自定义指令等高频知识点。每道题都配有详细解释和代码示例,适合用于前端开发岗位的 Vue 3 技术面试准备,大家可以码住随时翻出来查阅背诵和练习!


1. Vue 3 和 Vue 2 的区别是什么?

问题: 解释 Vue 3 相比 Vue 2 的主要改进点。(最主要,不是全部,全部后续老曹会再扩展)

答案:

特性Vue 2Vue 3
响应式系统Object.definePropertyProxy
架构单一源码模块化架构(Tree-shakable)
Composition API
Fragment
Suspense 组件
自定义渲染器支持有限更灵活
支持 TypeScript❌(需额外配置)✅ 原生支持
// Vue 3 示例:使用 Composition APIimport{ ref, onMounted }from'vue';exportdefault{setup(){const count =ref(0);functionincrement(){ count.value++;}onMounted(()=>{ console.log('组件挂载');});return{ count, increment };}};

2. 如何在 Vue 3 中创建一个响应式对象?

问题: 使用 reactive() 创建一个响应式用户对象。

答案:
使用 reactive() 创建深层响应式对象。

import{ reactive }from'vue';const user =reactive({ name:'Alice', age:25});

3. ref()reactive() 的区别?

问题: 写出两者的不同点及适用场景。

答案:

  • ref():适用于基本类型或单个值。
  • reactive():适用于对象或复杂结构。
import{ ref, reactive }from'vue';const count =ref(0);// 基本类型const user =reactive({ name:'Bob'});// 对象 count.value++;// 必须用 .value user.name ='Tom';// 不需要 .value

4. Vue 3 中如何监听数据变化?

问题: 使用 watchEffectwatch 的方式分别写出监听逻辑。

答案:

  • watchEffect:自动追踪依赖并执行副作用。
  • watch:手动指定监听的目标。
import{ ref, watchEffect, watch }from'vue';const count =ref(0);// watchEffectwatchEffect(()=>{ console.log('Count changed:', count.value);});// watchwatch(count,(newVal, oldVal)=>{ console.log(`从 ${oldVal} 变为 ${newVal}`);});

5. Vue 3 的生命周期钩子有哪些?如何使用?

问题:setup() 中使用 onMounted 生命周期钩子。

答案:
Vue 3 提供了与 Vue 2 类似的生命周期钩子,但必须从 vue 导入使用。

import{ onMounted }from'vue';exportdefault{setup(){onMounted(()=>{ console.log('组件已挂载');});}};

6. Vue 3 中如何进行父子组件通信?

问题: 父组件向子组件传递数据,并触发事件。

答案:
使用 props接收父组件数据,使用 emit 触发事件。

// 子组件 Child.vueexportdefault{ props:['title'], emits:['update'],setup(props,{ emit }){functionhandleClick(){emit('update','New Value');}return{ handleClick };}};// 父组件 Parent.vue<template><Child :title="msg" @update="handleUpdate"/></template><script>import Child from'./Child.vue';exportdefault{ components:{ Child },data(){return{ msg:'Hello'};}, methods:{handleUpdate(value){ console.log('收到更新:', value);}}};</script>

7. Vue 3 的 setup() 函数的作用是什么?

问题:setup() 是什么?为什么它很重要?

答案:

  • setup() 是 Vue 3 Composition API 的入口函数。
  • 替代 Vue 2 中的 datamethodscomputed 等选项。
  • 更好地组织逻辑复用和模块化代码。
exportdefault{setup(){const message =ref('Hello Vue 3');functionchangeMessage(){ message.value ='Updated!';}return{ message, changeMessage };}};

8. Vue 3 中如何实现响应式计算属性?

问题: 使用 computed() 实现一个计算属性。

答案:
使用 computed() 创建响应式计算属性。

import{ ref, computed }from'vue';exportdefault{setup(){const firstName =ref('John');const lastName =ref('Doe');const fullName =computed(()=>`${firstName.value}${lastName.value}`);return{ firstName, lastName, fullName };}};

9. provide()inject() 的作用是什么?

问题: 如何跨层级传递数据?

答案:
用于祖先组件向后代组件注入依赖,不通过 props 逐层传递。

// 祖先组件import{ provide, ref }from'vue';exportdefault{setup(){const theme =ref('dark');provide('theme', theme);return{ theme };}};// 后代组件import{ inject }from'vue';exportdefault{setup(){const theme =inject('theme');return{ theme };}};

10. Vue 3 中如何使用插槽(Slot)?

问题: 实现一个默认插槽和具名插槽。

答案:

<!-- 父组件 --><template><Card><template#default>这是默认插槽内容</template><template#header>这是头部插槽</template></Card></template><!-- 子组件 Card.vue --><template><divclass="card"><header><slotname="header"></slot></header><main><slot></slot></main></div></template>

11. Vue 3 中的 Teleport 有什么用途?

问题: 如何将模态框渲染到 <body> 下?

答案:
Teleport 可以将组件渲染到 DOM 中任意位置。

<template><teleportto="body"><divv-if="showModal"class="modal">这是一个模态框</div></teleport></template>

12. Vue 3 中的 Suspense 是什么?怎么用?

问题: 异步加载组件时显示加载状态。

答案:
Suspense 是一个内置组件,用于处理异步依赖。

<template><suspense><template#default><AsyncComponent/></template><template#fallback> 加载中... </template></suspense></template><script>const AsyncComponent =defineAsyncComponent(()=>import('./MyComponent.vue'));</script>

13. Vue 3 中的 definePropsdefineEmits 是什么?

问题:<script setup> 中如何声明 props 和 emits?

答案:
<script setup> 中直接使用 definePropsdefineEmits

<scriptsetup>import{ defineProps, defineEmits }from'vue';const props =defineProps(['title']);const emit =defineEmits(['update']);functionupdateTitle(){emit('update','New Title');}</script><template><h1>{{ title }}</h1><button@click="updateTitle">更新标题</button></template>

14. Vue 3 中如何动态绑定样式?

问题: 动态设置背景颜色。

答案:
使用 :style 绑定对象。

<template><div:style="{ backgroundColor: color }">{{ text }}</div></template><script>exportdefault{data(){return{ color:'lightblue', text:'动态样式'};}};</script>

15. Vue 3 中如何注册全局组件?

问题: 注册一个可全局使用的按钮组件。

答案:

// main.jsimport{ createApp }from'vue';import App from'./App.vue';import MyButton from'./components/MyButton.vue';const app =createApp(App); app.component('MyButton', MyButton); app.mount('#app');
<!-- 使用 --><template><my-buttonlabel="提交"/></template>

16. Vue 3 中如何实现自定义指令?

问题: 实现一个高亮指令 v-highlight

答案:

// main.jsimport{ createApp }from'vue';import App from'./App.vue';const app =createApp(App); app.directive('highlight',{mounted(el){ el.style.backgroundColor ='#f0e68c';}}); app.mount('#app');
<!-- 使用 --><template><pv-highlight>这段文字被高亮了</p></template>

17. Vue 3 中的 nextTick() 怎么用?

问题: 修改 DOM 后等待更新完成。

答案:
使用 nextTick() 确保 DOM 更新完成后执行操作。

import{ nextTick }from'vue';asyncfunctionupdateData(){this.message ='更新后的内容';awaitnextTick(); console.log('DOM 已更新');}

18. Vue 3 中如何实现组件懒加载?

问题: 使用异步组件实现路由懒加载。

答案:
使用 defineAsyncComponent 实现懒加载。

import{ defineAsyncComponent }from'vue';const AsyncComponent =defineAsyncComponent(()=>import('./components/LazyComponent.vue'));exportdefault{ components:{ AsyncComponent }};

19. Vue 3 中的 emitter 是什么?如何使用?

问题: 实现非父子组件之间的通信。

答案:
使用第三方库如 mittEventBus 实现全局通信。

npminstall mitt 
// eventBus.jsimport mitt from'mitt';exportconst emitter =mitt();// 发送事件import{ emitter }from'./eventBus'; emitter.emit('update','Hello');// 接收事件import{ emitter }from'./eventBus'; emitter.on('update',(msg)=>{ console.log(msg);});

20. Vue 3 中如何使用 v-model 实现双向绑定?

问题: 实现一个输入框组件的双向绑定。

答案:
使用 modelValue + update:modelValue

<template><input:value="modelValue"@input="$emit('update:modelValue', $event.target.value)"/></template><script>exportdefault{ props:['modelValue'], emits:['update:modelValue']};</script>

📋 总结表格

编号题目描述知识点示例代码常见考察点
1Vue3 与 Vue2 的区别架构升级Proxy, Composition API框架理解
2创建响应式对象reactive()reactive({})数据绑定
3ref() vs reactive()响应式机制ref(0) vs reactive({})数据封装
4数据监听watchEffect, watchwatch(count, () => {...})数据驱动
5生命周期钩子onMounted, onUpdatedonMounted(() => {})组件控制
6组件通信[props]/ emitdefineProps(['name'])组件设计
7setup() 的作用Composition API 入口setup() { return {} }逻辑组织
8计算属性computed()computed(() => a + b)响应式优化
9跨级传参provide/injectprovide('theme', 'dark')数据共享
10插槽使用默认插槽 / 具名插槽<slot name="header" />组件扩展
11Teleport 的用途渲染到其他节点<teleport to="body">...</teleport>DOM 结构优化
12Suspense 的用途异步加载<suspense><template #default>...异步组件
13<script setup> 中的 [props]/ emit快捷方式defineProps(['title'])新语法糖
14动态绑定样式:style:style="{ color: textColor }"样式控制
15全局组件注册component()app.component('MyButton', Button)组件复用
16自定义指令directive()app.directive('highlight', { mounted: ... })扩展能力
17nextTick() 的用途DOM 更新监听await nextTick()渲染流程控制
18组件懒加载异步组件defineAsyncComponent(() => import(...))性能优化
19全局事件通信mittemitter.on('event', fn)跨组件通信
20v-model 的实现双向绑定modelValue, update:modelValue表单组件设计

📌 高频考点补充

考点描述
Composition API替代 Options API,提升逻辑复用
Reactivity APIref, reactive, toRefs, watch, computed
Teleport / Portal渲染到任意 DOM 节点
Fragment支持多个根节点
TypeScript 支持完整 TS 类型推导
Custom Renderer可定制渲染器(如 Canvas、SSR)
性能优化更小的体积、更快的 Diff 算法
组合函数(Composable)封装可复用逻辑
Vue 3 的编译器优化Block Tree、Patch Flags
Vue 3 的生态支持Vite、Pinia、Vue Router 4、Element Plus

Read more

FPGA时钟架构解密:从SRCC/MRCC到全局时钟树的实战指南

FPGA时钟架构深度解析:从SRCC/MRCC到全局时钟树的高效设计实践 在FPGA设计中,时钟架构如同数字系统的心脏,其稳定性和效率直接影响整个设计的成败。Xilinx 7系列FPGA提供了丰富而复杂的时钟资源,包括SRCC、MRCC、BUFG、BUFMR等组件,它们共同构成了一个多层次的时钟分配网络。本文将带您深入探索这些关键组件的特性和应用场景,揭示如何构建高性能、低抖动的时钟分配方案。 1. SRCC与MRCC:时钟输入的起点 SRCC(Single Region Clock Capable)和MRCC(Multi-Region Clock Capable)是7系列FPGA中两类特殊的时钟输入引脚,它们构成了外部时钟信号进入FPGA的第一道门户。理解它们的差异对于优化时钟分配至关重要。 物理布局特性: * 每个I/O bank包含2对MRCC和2对SRCC引脚 * MRCC引脚通常位于bank的特定位置,便于跨区域时钟分配 * SRCC引脚分布更均匀,适合局部时钟需求 功能对比表: 特性SRCCMRCC驱动范围单一时钟区域最多三个相邻区域可驱动缓冲器类

Flutter 组件 bip340 适配鸿蒙 HarmonyOS 实战:次世代 Schnorr 签名,为鸿蒙 Web3 与隐私计算筑牢加密防线

Flutter 组件 bip340 适配鸿蒙 HarmonyOS 实战:次世代 Schnorr 签名,为鸿蒙 Web3 与隐私计算筑牢加密防线

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net Flutter 组件 bip340 适配鸿蒙 HarmonyOS 实战:次世代 Schnorr 签名,为鸿蒙 Web3 与隐私计算筑牢加密防线 前言 在鸿蒙(OpenHarmony)生态迈向去中心化金融(DeFi)、隐私通讯及安全资产管理等高阶安全场景的背景下,如何实现更高性能、更具扩展性且抗攻击能力的数字签名架构,已成为决定应用闭环安全性的“压舱石”。在鸿蒙设备这类强调分布式鉴权与芯片级安全(TEE/SE)的移动终端上,如果依然沿用传统的 ECDSA 签名算法,由于由于其固有的可延展性风险与高昂的聚合验证成本,极易由于由于在大规模节点验证时的 CPU 负载过高导致交互滞后。 我们需要一种能够实现签名线性聚合、计算逻辑极简且具备原生抗延展性的密码学方案。 bip340 为 Flutter 开发者引入了比特币 Taproot 升级的核心——Schnorr 签名算法。它不仅在安全性上超越了传统标准,更通过其线性的数学特性,

堪称全网最详细的前端面试八股文,面试必备(附答案)

面试官翻开你的简历时,已经在心里问出了这三个问题,而大多数人倒在了第二个。 作为面试过近200名前端工程师的技术负责人,我见过太多候选人带着漂亮的简历走进会议室——Vue/React全家桶倒背如流、项目经历写得满满当当、算法题刷了成百上千道。 可当我开始问「为什么选择这个架构方案」、「如果让你重新设计这个组件会怎么做」、「这个技术决策背后的业务逻辑是什么」 时,超过60% 的候选人都会出现短暂的沉默。 前端面试早已不是「背API就能过」的时代了。今天的面试官想看到的,是框架背后的设计思维、是业务场景下的技术决策逻辑、是代码之外的工程化素养。 这篇文章将彻底拆解前端面试中的核心八股文,但不止于标准答案——我会带你还原每一个技术问题背后的真实考察意图,并附上能让面试官眼前一亮的深度解析。 全文目录: 1.JavaScript面试题(323题) 2.CSS面试题(61题) 3.HTML面试题(57题) 4.React面试题(83题) 5.Vue面试题(80题) 5.算法面试题(19题) 7.计算机网络(71题) 8.

前端异常捕获与统一格式化:从 console.log(error) 到服务端上报

前端异常捕获与统一格式化:从 console.log(error) 到服务端上报

🧑 博主简介:ZEEKLOG博客专家,「历代文学网」(公益文学网,PC端可以访问:https://lidaiwenxue.com/#/?__c=1000,移动端可关注公众号 “ 心海云图 ” 微信小程序搜索“历代文学”)总架构师,首席架构师,也是联合创始人!16年工作经验,精通Java编程,高并发设计,分布式系统架构设计,Springboot和微服务,熟悉Linux,ESXI虚拟化以及云原生Docker和K8s,热衷于探索科技的边界,并将理论知识转化为实际应用。保持对新技术的好奇心,乐于分享所学,希望通过我的实践经历和见解,启发他人的创新思维。在这里,我希望能与志同道合的朋友交流探讨,共同进步,一起在技术的世界里不断学习成长。 🤝商务合作:请搜索或扫码关注微信公众号 “ 心海云图 ” 前端异常捕获与统一格式化:从 console.log(error) 到服务端上报 引言 在前端开发中,异常监控是保证应用稳定性的重要一环。当用户遇到页面白屏、功能不可用等问题时,如果能及时收集到详细的错误信息(包括堆栈、