Vue3高频面试题1

2024-08-29 12:12

本文主要是介绍Vue3高频面试题1,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1、vue2和vue3的区别是什么

  1. Composition API vs Options API*
    • Composition API:组合式API
    • Options API:选项式API——在vue2中使用
    • 它们两者在vue3中是组织代码不同方式
    • Vue3引入了Composition API,更灵活、易于组织代码,相较于Vue2Options API更具优势。
  2. 性能优化
    • Vue3在虚拟DOM和响应式系统方面进行了多项性能优化,提升了页面加载速度和渲染效率。
    • 使用了更高效的算法减少了不必要的dom更新
    • 使用了proxy对属性的变化进行监听,并在需要进行页面更新的时候批量的进行操作
  3. TypeScript支持
    • 简称TS——它其实就是一种静态类型的检查工具,方便在开发的时候就发现问题
    • Vue3更好地支持TypeScript,提供更好的类型检查和推断,有助于减少潜在错误。
  4. 新增功能
    • Vue3引入了Teleport、Suspense等新功能,简化了处理复杂逻辑和异步操作的方式。
    • 方便的把组件中的一些dom模板移动到dom树中的任何内容、任何位置
  5. 树型组件优化
    • Vue3优化了树型组件的性能,特别是对于大型列表的渲染,表现更为出色。
  6. 全局API调整
    • Vue3对全局API进行了调整和统一,使整个框架更加一致和易于理解。
  7. 包大小优化
    • Vue3的包大小相较于Vue2有所减小,剔除了一些冗余代码,提升了整体性能。
  8. Tree-shaking效果
    • Vue3采用ES模块组织代码,优化了Tree-shaking的效果,减少了不必要的代码被打包到生产环境。
    • Tree-shaking:打包编译时把一些不必要的代码自动剔除掉
  9. 更佳的响应式原理
    • Vue3重新设计了响应式系统,使变化侦测更加精确高效,提供更出色的性能表现。
      逻辑复用与共享
    • Composition API让逻辑复用和共享更加便捷灵活,让代码组织更加清晰和高效。
  10. 注意
    • 以上不是所有的区别内容
    • 但是,面试回答已经足够用了,也是主要的区别

2、介绍setup—包含参数、返回值

  1. 概念
    • setup是vue3中的CompositionAPI(组合式API)的启动器
    • 它会在beforecreate 与created之间去自执行
    • setup有2个形参
    • setup有2种返回值
  2. 两个形参
    • props:props就是接收父组件传递过来的属性
    • context:有三个属性
      • attrs:attrs获取当前标签上面的所有属性的对象,但不能和props属性连用,如果连用了,那么会返回什么都没有——即:props属性接收的数据,attrs不可以重复接收
      • emit:emit自定义事件
      • slots:插槽,带有dom的属性(用来接收父组件传递的html内容)
  3. 两种返回值
    • 对象:
      • 对象:就是要把定义在setup中的属性与方法必须返回出去 要不然模板不能使用
    • 返回渲染函数:
      • 渲染函数:返回渲染函数的优先级比写在模板中的内容优先级高,所以写了渲染函数会覆盖原有的模板内容
      • 如果要返回渲染函数,还要配合vue中提供的h函数或者是createVNode函数,其中createVNode()函数的功能比h()函数要多且做了性能优化,渲染节点的速度也更快。

3、计算属性和函数方法的区别

  1. 最大的区别是:缓存惰性这个概念
  2. 函数:调用多少次,就是打印多少次
  3. 所以在性能上来说,函数更加浪费性能,计算属性更加节省性能,而且处理速度更快,因为它只执行一次(不改变依赖数据的情况下),函数则执行多次
  4. 相比于函数计算属性具有自动缓存依赖追踪的优势,更适合进行派生计算

4、watchEffect 与 watch 的区别

  1. 不需要手动传入依赖,它对整个组件中所有的数据自动的来完成监听
  2. 每次初始化时会执行一次回调函数来自动获取依赖
  3. 无法获取到原值,只能得到变化后的值,只有newVal,没有oldVal
  4. watch是惰性的,因此仅当依赖项更改时才会触发,也就是说:watch在初始化的时候不会执行,当监听的响应式数据改变了,watch才会执行
  5. watchEffect在创建组件后立即运行,然后跟踪依赖关系。

5、vue3中没有过滤器了,如果想实现相同的功能怎么办

  1. 编写一个函数参数为:需要格式化(处理/过滤)的数据
  2. return处理好的数据 ,如:年月日只展示年份,就用截取功能

6、父组件如何触发子组件中的方法

  1. 通过ref配合defineExpose即可实现
  2. 子组件中通过defineExpose暴露方法,在父组件中使用ref来接收
  3. 再通过xxx.value.方法名()即可调用

7、组件传值的实现——从父子及兄弟角度出发

  1. 父子组件传值
    • 使用 Props:父组件通过 Props 向子组件传递数据,子组件通过 defineProps 接收数据。
    • 使用 Provide/Inject:祖先组件通过 provide 提供数据,后代组件通过 inject 注入数据。这会导致组件之间的耦合性增加,应谨慎使用。
  2. 子父组件传值
    • 使用Events:子组件通过 emit 方法触发自定义事件向父组件传递数据,父组件通过在子组件上使用 @eventName 监听事件来接收数据。
  3. 兄弟组件传值
    • 使用事件总线(Event Bus):创建一个空的Vue实例作为事件总线
    • 兄弟组件通过事件总线来通信。

8、生命周期的钩子函数

  1. onBeforeMount:在组件挂载之前调用,仅触发一次。
  2. onMounted:组件挂载完成后调用,此时DOM已经生成,可以进行DOM操作。
  3. onBeforeUpdate:在组件更新之前调用,此时数据已变化,但DOM未更新。
  4. onUpdated:组件更新完成后调用,此时DOM已更新。
  5. onBeforeUnmount:在组件卸载之前调用,可用于清理操作。
  6. onUnmounted:组件卸载后调用,用于执行最后的清理操作。
  7. onErrorCaptured:在捕获子组件树中的错误时调用,可用于全局错误处理。

9、vuex中的5个属性

  1. State:存储应用的全局状态,类似于组件中的data。
  2. Getters:从State中派生出计算属性,类似于组件中的computed。
  3. Mutations:同步更改State的方法,必须是同步操作。
  4. Actions:用于提交Mutations,可以包含异步操作。
  5. Modules:将StateGettersMutationsActions分割成模块,便于管理大型应用。

这篇关于Vue3高频面试题1的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1117827

相关文章

CSS弹性布局常用设置方式

《CSS弹性布局常用设置方式》文章总结了CSS布局与样式的常用属性和技巧,包括视口单位、弹性盒子布局、浮动元素、背景和边框样式、文本和阴影效果、溢出隐藏、定位以及背景渐变等,通过这些技巧,可以实现复杂... 一、单位元素vm 1vm 为视口的1%vh 视口高的1%vmin 参照长边vmax 参照长边re

CSS3中使用flex和grid实现等高元素布局的示例代码

《CSS3中使用flex和grid实现等高元素布局的示例代码》:本文主要介绍了使用CSS3中的Flexbox和Grid布局实现等高元素布局的方法,通过简单的两列实现、每行放置3列以及全部代码的展示,展示了这两种布局方式的实现细节和效果,详细内容请阅读本文,希望能对你有所帮助... 过往的实现方法是使用浮动加

css渐变色背景|<gradient示例详解

《css渐变色背景|<gradient示例详解》CSS渐变是一种从一种颜色平滑过渡到另一种颜色的效果,可以作为元素的背景,它包括线性渐变、径向渐变和锥形渐变,本文介绍css渐变色背景|<gradien... 使用渐变色作为背景可以直接将渐China编程变色用作元素的背景,可以看做是一种特殊的背景图片。(是作为背

CSS自定义浏览器滚动条样式完整代码

《CSS自定义浏览器滚动条样式完整代码》:本文主要介绍了如何使用CSS自定义浏览器滚动条的样式,包括隐藏滚动条的角落、设置滚动条的基本样式、轨道样式和滑块样式,并提供了完整的CSS代码示例,通过这些技巧,你可以为你的网站添加个性化的滚动条样式,从而提升用户体验,详细内容请阅读本文,希望能对你有所帮助...

css实现图片旋转功能

《css实现图片旋转功能》:本文主要介绍了四种CSS变换效果:图片旋转90度、水平翻转、垂直翻转,并附带了相应的代码示例,详细内容请阅读本文,希望能对你有所帮助... 一 css实现图片旋转90度.icon{ -moz-transform:rotate(-90deg); -webkit-transfo

vue基于ElementUI动态设置表格高度的3种方法

《vue基于ElementUI动态设置表格高度的3种方法》ElementUI+vue动态设置表格高度的几种方法,抛砖引玉,还有其它方法动态设置表格高度,大家可以开动脑筋... 方法一、css + js的形式这个方法需要在表格外层设置一个div,原理是将表格的高度设置成外层div的高度,所以外层的div需要

Vue项目中Element UI组件未注册的问题原因及解决方法

《Vue项目中ElementUI组件未注册的问题原因及解决方法》在Vue项目中使用ElementUI组件库时,开发者可能会遇到一些常见问题,例如组件未正确注册导致的警告或错误,本文将详细探讨这些问题... 目录引言一、问题背景1.1 错误信息分析1.2 问题原因二、解决方法2.1 全局引入 Element

详解如何在React中执行条件渲染

《详解如何在React中执行条件渲染》在现代Web开发中,React作为一种流行的JavaScript库,为开发者提供了一种高效构建用户界面的方式,条件渲染是React中的一个关键概念,本文将深入探讨... 目录引言什么是条件渲染?基础示例使用逻辑与运算符(&&)使用条件语句列表中的条件渲染总结引言在现代

详解Vue如何使用xlsx库导出Excel文件

《详解Vue如何使用xlsx库导出Excel文件》第三方库xlsx提供了强大的功能来处理Excel文件,它可以简化导出Excel文件这个过程,本文将为大家详细介绍一下它的具体使用,需要的小伙伴可以了解... 目录1. 安装依赖2. 创建vue组件3. 解释代码在Vue.js项目中导出Excel文件,使用第三

Java实现Excel与HTML互转

《Java实现Excel与HTML互转》Excel是一种电子表格格式,而HTM则是一种用于创建网页的标记语言,虽然两者在用途上存在差异,但有时我们需要将数据从一种格式转换为另一种格式,下面我们就来看看... Excel是一种电子表格格式,广泛用于数据处理和分析,而HTM则是一种用于创建网页的标记语言。虽然两