likes
comments
collection
share

前端面试 ===> 【Vue3】

作者站长头像
站长
· 阅读数 8

Vue3 面试题总结

1. OptionsAPI 与 CompositionAPI 的区别?

  • OptionsAPI
    • 选项式API,通过定义data、computed、watch、method等属性与方法,共同处理页面逻辑;
    • 缺点:
      • 当组件变得复杂的时候,导致对应属性的列表也会增长,可能会导致组件难以阅读和后期维护成本变高;
  • CompositionAPI
    • 组合式API,组件根据逻辑功能来组织,一个功能所定义的所有API会放在一起(高内聚,低耦合);
    • 优点:
      • 内部的功能容易碎片化,像某一个功能相关的数据放在一块,容易阅读和维护(不用翻来翻去找);
      • 将某个逻辑关注点相关的代码全都放在一个函数里,这样,当需要修改一个功能时,就不再需要在文件中跳来跳去;
      • 逻辑复用:
        • 在Vue2中,当混入多个mixin会存在两个非常明显的问题:命名冲突,数据来源不清晰;
        • 而组合式API可以通过编写多个函数就很好的解决了;
  • 总结
    • 在逻辑组织和逻辑复用这方面,组合式API是优于选项式API的;
    • 组合式API中见不到this的使用,减少了this指向不明的情况;
    • 组合式API几乎都是函数,会有更好的类型推断;

2. Vue3中为什么采用 Proxy 代替 definePrototype

  • definePrototype
    • 来劫持整个对象,然后进行深度遍历,给每个属性添加 gettersetter,实现响应式,但是存在以下问题:
      • 检测不到对象属性的添加和删除;
      • 数组API方法无法监听到;
      • 需要对每个属性进行深度遍历,如果是嵌套对象,需要深层次监听,造成性能问题;
  • Proxy
    • 监听整个对象,那么整个对象的所有操作都会进入监听操作;
  • 总结
    • Object.definePrototype 只能遍历对象属性进行劫持;
    • Proxy 直接可以劫持整个对象,便返回一个新对象,我们可以操作新对象达到响应式目的;
    • Proxy 可以直接监听数组的变化;
    • Proxy有13种拦截方法,不限于apply、ownKeys、deleteProperty、has等等,这是Object.defineProperty不具备的;

3. Vue3响应式原理

  • Vue响应式使用的是ES6的ProxyReflect相互配合实现数据响应式,解决了Vue2中试图不能自动更新的问题;
  • Proxy是深度监听,所以可以监听对象和数组内的任意元素,从而可以实现视图实时更新;
  • 响应式大致分为三个阶段:
    • 初始化阶段
      • 初始化阶段通过组件初始化方法形成对应的proxy对象,然后形成一个负责渲染的effct
    • get依赖收集阶段
      • 通过解析template,替换真实data属性,来触发get,然后通过satck方法,通过proxy对象key形成对应的deps,将负责渲染的effect存入deps。(这个过程还有其他的effect,比如watchEffect存入deps中 )。
    • set派发更新阶段
      • 当我们 this[key] = value 改变属性的时候,首先通过trigger方法,通过proxy对象key找到对应的deps,然后给deps分类分成computedRunnerseffect,然后依次执行,如果需要调度的,直接放入调度。

Proxy只会代理对象的第⼀层,那么Vue3⼜是怎样处理这个问题的呢?

  • 判断当前Reflect.get的返回值是否为Object,如果是则再通过 reactive ⽅法做代理, 这样就实现了深度观测。

监测数组的时候可能触发多次get/set,那么如何防⽌触发多次呢?

  • 我们可以判断key是否为当前被代理对象target⾃身属性,也可以判断旧值与新值是否相等,只有满⾜以上两个条件之⼀时,才有可能执⾏trigger。

4. watch 和 watchEffect 的区别?

  • watchwatchEffect 都是监听器,watchEffect 是一个副作用函数,它们之间的区别有:
  1. watch:既要指明监听数据的源,也要指明监听的回调;
  2. watchEffect:可以自动监听数据源作为依赖,不用指明监听那个数据,监听的回调中用到哪个数据,那就监听哪个数据;
  3. watch 可以访问改变前后的值,watchEffect 只能获取改变后的值;
  4. watch运行的时候 不会立即执行,值改变后才会执行,而watchEffect运行后可立即执行,这一点可以通过watch的配置项immeriate改变;
  5. watchEffect 有点像 computed
    • computed注重的是计算出来的值(回调函数的返回值),所以必须写返回值;
    • watchEffect注重的是过程(回调函数的函数体),所以不用写返回值;
      • watchEffect所指定的回调中用到的数据只要发生变化,则直接重新执行回调;
  6. Vue3与Vue2中的watch配置项一致,但也有两个小坑:
    • 监听reactive定义的响应式数据时,oldVal无法正确获取到,强制开启深度监听,depp配置项失效;
    • 监听reactive定义的响应式数据的某个属性时,deep配置项有效;

5. ref 与 reactive 的区别?

  1. refreactive它们主要用于响应式数据的创建;
  2. ref函数可以接收原始数据类型和引用数据类型;
  3. 使用ref声明的数据,在JS中使用的时候,需要添加.value的后缀;
  4. reactive函数只能接收引用数据类型;
  5. ref底层还是使用reactive来做,ref是在reactive上进行了封装,增强了其能力,使其支持了对原始数据类型的处理;
  6. Vue3中,reactive能做的ref能做,reactive不能做的ref也能做;

6. script setup 是干什么的?

  • script setup是Vue3的语法糖,简化了组合式API的写法,并且运行性能更高,使用script setup语法糖的特点:
  1. 属性和方法无需返回,直接使用;
  2. 引入组件的时候,会自动注册;
  3. 使用defineProps接收父组件传递的值;
  4. 使用useAttrs获取属性,useSlots获取插槽,defineEmits获取自定义事件;
  5. 默认不会对外暴露任何属性,如果有需要使用defineExpose

7. vFor 与 vIf 的优先级

  • 当面试官问到这个问题的时候,我们不能直接说前者比后者高(或者后者比前者高);
  • 我们应当根据Vue的不同版本做不同的回答;
  • Vue2
    • vFor 高于 vIf
  • Vue3
    • vIf 高于 vFor
  • 两个版本的区别
    • Vue2中,可以一起使用,但是非常不推荐哈,vIf也能获取到vFor中的item
    • Vue3中,不能一起使用,因为vIf不能使用vFor中的item(会直接报错,不能从 undefined中读取xxx属性);
      • 前端面试 ===> 【Vue3】