2024 前端高频面试题之 Vue 篇


1、v-for 和 v-if 可以混合使用吗?为什么?

可以,但是尽量不要同时使用v-for计算优先级比v-if高,首先会把虚拟节点渲染出来,然后再进行v-if判断。降低渲染性能

2、v-for 中为什么加 key?

如果不使用 keyVue 会使用一种最大限度减少动态元素并且尽可能的尝试就地修改/复用相同类型元素的算法。key 是为 Vuevnode 的唯一标记,通过这个 keydiff 算法可以更准确、更快速

  • 更准确:因为带 key 就不是就地复用了,在 sameNode 函数 a.key === b.key 对比中可以避免就地复用的情况。所以会更加准确。
  • 更快速:利用 key 的唯一性生成 map 对象来获取对应节点,比遍历方式更快

3、事件默认有个 event 参数,它是什么?怎么使用?事件被绑定到哪里?

当事件没有参数,则默认有个 event 参数;如果有自定义参数,则需要使用$event 传过去。

  • event 的构造函数是 MouseEvent,即是原生的 event 对象
  • event 被挂载到当前元素下,即 event.target

4、vue 父子组件如何通讯?

  • props、$emit:

    父组件使用动态数据传递,子组件使用props接收,可以使用数组/对象数据结构,对象结构可以定义类型和默认值。

    子组件使用$emit 事件回传
  • 自定义事件进行组件通讯

    自定义事件就是使用一个额外的 js 文件,其中声明一个 Vue 实例即可

    $on$emit$off,参数分别是:注册函数名,真实函数

    $on:绑定自定义事件

    $emit:调用自定义事件

    $off:在组件销毁时,要及时销毁自定义事件,否则可能会造成内存泄漏。在 beforeDestroy 中调用$off
  • $refs

    获取当前组件实例
  • $parent&$children

    获取当前组件的父组件和子组件
  • vuex

    Vue 中全局状态管理系统,用于多个组件中数据共享。
  • provide&inject

    上层组件提供,下层组件注入使用。(适用于组件库编写)

5、父子组件声明周期调用顺序?

  • 加载渲染过程

    beforeCreate -> 父created -> 父beforeMount -> 子beforeCreate -> 子created -> 子beforeMount -> 子mounted -> 父mounted
  • 更新过程

    beforeUpdate -> 子beforeUpdate -> 子updated -> 父updated
  • 销毁过程

    beforeDestroy -> 子beforeDestroy -> 子destroyed -> 父destroyed
  • 全流程

    beforeCreate -> created -> beforeMount -> mounted -> beforeUpdate -> updated -> beforeDestroy -> destroyed

6、vue 双向绑定原理(响应式原理)?

采用数据劫持结合观察者模式的方式

通过 Object.defineProperty()来劫持各个属性(只会劫持已经存在的属性)的 settergetterdepWatcher 实现依赖收集和派发更新的过程:

  • vuedata 初始化为一个 Observer 并对对象中的每个值,重写了其中的 getsetdata 中的每个 key,都有一个独立的 dep(依赖收集器)。
  • get 中,
  • 78
    点赞
  • 506
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
回答: 根据引用,这份面试题涵盖了Vue.js的基础知识和高级概念,包括组件、生命周期、异步操作和跨域请求,以及Vue框架的优势、vue-router和服务端渲染(SSR)等。对于准备Vue.js面试的人来说,这份问题列表应该是非常有用的资源。 在回答你提到的其他问题之前,让我先回答第32和第33个问题。根据引用,GET请求和POST请求在底层都是基于TCP/IP协议实现的,都可以实现客户端和服务器端的双向交互。最本质的区别在于约定和规范。GET请求用于获取资源,进行查询操作,而POST请求用于传输实体对象,用于增删改操作。约定上,GET请求将参数拼接到URL上进行参数传递,而POST请求将参数写入请求正文中传递。这样的约定和规范有助于保持请求的语义和一致性。 关于第33个问题,数组去重,可以使用不同的方法来实现。一种常见的方法是使用Set数据结构,因为Set只会存储不重复的值。可以将数组转换为Set,然后再将Set转换回数组即可。另一种方法是使用循环和条件判断,遍历数组,将不重复的元素添加到一个新数组中。这样可以去除数组中的重复元素。 希望这些回答对你有帮助。如果你还有其他问题,请随时提问。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [2023前端vue高频面试题](https://blog.csdn.net/qq_27244301/article/details/129619172)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [2023最新高频前端面试题总结(附答案)](https://blog.csdn.net/jewels_w/article/details/125899379)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值