刷刷题30(vue3常规面试题)

1. ‌Vue 3的组合式API(Composition API)与选项式API(Options API)的核心区别是什么?在什么场景下推荐使用组合式API?

  • ‌:
    组合式API通过setup()函数组织逻辑,允许按功能拆分代码(如ref, reactive, computed),解决选项式API中逻辑分散的问题(如datamethods分离)。
    适合复杂组件、逻辑复用(自定义Hook)或TypeScript项目,提升代码可维护性。

2. ‌Vue 3的响应式数据中,refreactive有什么区别?如何决定使用哪一个?

  • ‌:

    • ref:包装基本类型(如string, number),通过.value访问,可用于任何数据类型。
    • reactive:仅接收对象类型,自动深层响应式,直接访问属性,解构可能丢失响应性。
    • 选择 ‌:基本类型用ref;复杂对象用reactive,需保持引用时用toRefs解构。

3. ‌Vue 3中如何监听响应式数据的变化?watchwatchEffect有何区别?

  • ‌:

    • watch:需指定监听的具体数据源和回调,可配置immediatedeep
    • watchEffect:自动追踪回调内的依赖,立即执行,适用于依赖动态变化的场景。
    • 区别 ‌:watch精确控制依赖,watchEffect自动收集依赖,更简洁。

4. ‌Vue 3的setup函数中如何访问组件实例的propscontext

  • 答案 ‌:
    setup(props, context)

    • props:响应式对象,不可解构,需用toRefs保持响应性。
    • context:包含attrsslotsemit等非响应式属性。

5. ‌Vue 3的Teleport组件有什么作用?举一个实际应用场景。

  • ‌:

    作用 ‌:将子组件渲染到DOM的指定位置(如body末尾),解决模态框、弹窗的样式层级问题。

    示例‌:

ini 复制代码
<teleport to="#modal-container">
  <div v-if="showModal">模态框内容</div>
</teleport>

6. ‌Vue 3如何实现多个v-model绑定?

  • 通过给v-model添加参数:

ini 复制代码
<ChildComponent v-model:title="pageTitle" v-model:content="pageContent" />

子组件用emit('update:title', newValue)触发更新。

7. ‌解释Vue 3的响应式原理,对比Vue 2的Object.defineProperty

  • ‌:

    • Vue 3 ‌:使用Proxy代理对象,支持监听属性新增/删除、数组索引变化,无需递归初始化。
    • Vue 2 ‌:Object.defineProperty无法检测数组索引/对象属性增减,需用Vue.set

8. ‌Vue 3中如何优化组件渲染性能?举两个例子。

  • 答案‌:

    • v-memo‌:缓存静态内容,避免重复渲染。
css 复制代码
<div v-memo="[value]">{{ value }}</div>
  • 异步组件 ‌:使用defineAsyncComponent延迟加载非关键组件。
  • 优化策略 ‌:减少响应式数据嵌套、合理使用shallowRef/shallowReactive

9. ‌如何用Vue 3的自定义Hook实现逻辑复用?编写一个鼠标位置跟踪的Hook。

ini 复制代码
// useMousePosition.js
import { ref, onMounted, onUnmounted } from 'vue';

export function useMousePosition() {
  const x = ref(0);
  const y = ref(0);

  const update = (e) => {
    x.value = e.clientX;
    y.value = e.clientY;
  };

  onMounted(() => window.addEventListener('mousemove', update));
  onUnmounted(() => window.removeEventListener('mousemove', update));

  return { x, y };
}

// 组件内使用
const { x, y } = useMousePosition();

10. ‌Vue 3的<script setup>语法糖解决了哪些问题?举例说明其用法。

  • ‌:

    优势 ‌:简化组合式API的样板代码,自动暴露顶层变量。

    示例‌:

xml 复制代码
<script setup>
import { ref } from 'vue';
const count = ref(0);
// 直接使用,无需return
</script>
<template>
  <button @click="count++">{{ count }}</button>
</template>
相关推荐
answerball1 小时前
🔥 Vue3响应式源码深度解剖:从Proxy魔法到依赖收集,手把手教你造轮子!🚀
前端·响应式设计·响应式编程
Slow菜鸟2 小时前
ES5 vs ES6:JavaScript 演进之路
前端·javascript·es6
小冯的编程学习之路2 小时前
【前端基础】:HTML
前端·css·前端框架·html·postman
Jiaberrr3 小时前
Vue 3 中搭建菜单权限配置界面的详细指南
前端·javascript·vue.js·elementui
科科是我嗷~3 小时前
【uniapp】textarea maxlength字数计算不准确的问题
javascript·uni-app·html
懒大王95273 小时前
uniapp+Vue3 组件之间的传值方法
前端·javascript·uni-app
烛阴4 小时前
秒懂 JSON:JavaScript JSON 方法详解,让你轻松驾驭数据交互!
前端·javascript
拉不动的猪4 小时前
刷刷题31(vue实际项目问题)
前端·javascript·面试
zeijiershuai4 小时前
Ajax-入门、axios请求方式、async、await、Vue生命周期
前端·javascript·ajax
恋猫de小郭4 小时前
Flutter 小技巧之通过 MediaQuery 优化 App 性能
android·前端·flutter