以下是老曹关于 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 API

import { ref, onMounted } from 'vue';

export default {

setup() {

const count = ref(0);

function increment() {

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 中如何监听数据变化?

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

答案:

watchEffect:自动追踪依赖并执行副作用。watch:手动指定监听的目标。

import { ref, watchEffect, watch } from 'vue';

const count = ref(0);

// watchEffect

watchEffect(() => {

console.log('Count changed:', count.value);

});

// watch

watch(count, (newVal, oldVal) => {

console.log(`从 ${oldVal} 变为 ${newVal}`);

});

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

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

答案:

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

import { onMounted } from 'vue';

export default {

setup() {

onMounted(() => {

console.log('组件已挂载');

});

}

};

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

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

答案:

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

// 子组件 Child.vue

export default {

props: ['title'],

emits: ['update'],

setup(props, { emit }) {

function handleClick() {

emit('update', 'New Value');

}

return { handleClick };

}

};

// 父组件 Parent.vue

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

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

答案:

setup() 是 Vue 3 Composition API 的入口函数。替代 Vue 2 中的 data、methods、computed 等选项。更好地组织逻辑复用和模块化代码。

export default {

setup() {

const message = ref('Hello Vue 3');

function changeMessage() {

message.value = 'Updated!';

}

return { message, changeMessage };

}

};

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

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

答案:

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

import { ref, computed } from 'vue';

export default {

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';

export default {

setup() {

const theme = ref('dark');

provide('theme', theme);

return { theme };

}

};

// 后代组件

import { inject } from 'vue';

export default {

setup() {

const theme = inject('theme');

return { theme };

}

};

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

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

答案:

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

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

答案:

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

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

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

答案:

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

13. Vue 3 中的 defineProps 和 defineEmits 是什么?

问题: 在

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

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

答案:

使用 :style 绑定对象。

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

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

答案:

// main.js

import { 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');

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

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

答案:

// main.js

import { createApp } from 'vue';

import App from './App.vue';

const app = createApp(App);

app.directive('highlight', {

mounted(el) {

el.style.backgroundColor = '#f0e68c';

}

});

app.mount('#app');

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

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

答案:

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

import { nextTick } from 'vue';

async function updateData() {

this.message = '更新后的内容';

await nextTick();

console.log('DOM 已更新');

}

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

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

答案:

使用 defineAsyncComponent 实现懒加载。

import { defineAsyncComponent } from 'vue';

const AsyncComponent = defineAsyncComponent(() =>

import('./components/LazyComponent.vue')

);

export default {

components: {

AsyncComponent

}

};

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

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

答案:

使用第三方库如 mitt 或 EventBus 实现全局通信。

npm install mitt

// eventBus.js

import mitt from 'mitt';

export const 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。

📋 总结表格

编号题目描述知识点示例代码常见考察点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插槽使用默认插槽 / 具名插槽组件扩展11Teleport 的用途渲染到其他节点...DOM 结构优化12Suspense 的用途异步加载