首页 > 其他分享 >【手撕面试题】Vue(高频知识点三)

【手撕面试题】Vue(高频知识点三)

时间:2024-06-02 10:31:33浏览次数:19  
标签:知识点 面试题 Vue dom 面试官 vue 使用 组件 数据

        每天10道题,100天后,搞定所有前端面试的高频知识点,加油!!!在看文章的同时,希望不要直接看答案,先思考一下自己会不会,如果会,自己的答案是什么?想过之后再与答案比对,是不是会更好一点,当然如果你有比我更好的答案,欢迎评论区留言,一起探讨技术之美。

目录

面试官:请简述一下vue中mixin的使用场景和原理。

面试官:请简述一下你对v-for中key的理解。

面试官:请讲一下你对vue中transition的理解。

面试官:请讲一下你对vue中的diff算法的理解。

面试官:vue通过数据劫持就可以精准探测数据变化,为什么还要进行diff检测差异?

面试官:请解释一下vue为什么要使用虚拟dom,详细解释一下原理。

面试官:请问如果vuex页面刷新数据丢失怎么解决?

面试官:请叙述一下vue中使用了哪些设计模式?

面试官:请简述一下vue中的性能优化可以从哪几个方面去思考设计?

面试官:nextTick的作用是什么?实现原理是什么?


面试官:请简述一下vue中mixin的使用场景和原理。

我,呃~,在vue中mixin是一种可重用的功能模块,它可以包含一组vue组件选项,如数据、计算属性、方法和生命周期钩子等,可以被多个组件引用,以实现代码复用和组件间的功能功能,这里简单说一下其使用场景和原理:

使用场景

1)代码复用:多组件需要共享相同逻辑或功能时,可以将这些功能封装到mixin中

2)跨组件通信:将一些状态或方法定义在mixin中,多组件可以共享这些状态或方法

3)功能增强:可以添加一些全局方法、事件处理器或样式来增强组件的功能

原理

mixin是通过混入式继承的方式实现,即mixin中的选项会被混合到组件中,形成一个新的组件选项,这样组件就可以拥有mixin中定义的所有功能,当一个组件使用mixin时,vue会将mixin中的选项与组件选项进行合并,如果有冲突选项通常mxin中的选项会覆盖组件中的选项。

面试官:请简述一下你对v-for中key的理解。

我,呃~,key是v-for指令中的一个特殊属性,用于帮助vue识别节点的唯一性,以便更高效地更新虚拟DOM,在使用v-for指令循环渲染列表时,每个列表项都需要一个唯一的标识符,以便vue能够准确地追踪每个节点的变化。如果没有提供key,vue会尝试使用节点的索引作为标识符,但这样可能导致一些问题,尤其是在列表中的项目动态排序、过滤或删除时。

作用就是:

1)节点唯一性

2)DOM元素复用

3)避免状态丢失

4)提高渲染性能

总之:key在v-for循环渲染列表时是非常重要的,它可以帮助Vue更高效地管理dom,并确保列表渲染的正确性和性能,因此在使用v-for时,务必为每个列表项提供唯一的key,并尽量避免频繁改变key的值。

面试官:请讲一下你对vue中transition的理解。

我,呃~,在vue中transition是一种用于在元素进入或离开vue管理的dom的过渡效果的特殊指令,通过使用transition开发者可以为元素在进入或离开时添加动画效果,使用户界面更具吸引力和流畅性,下面对transition的一些概念和用法进行一个大概的讲解:

1)进入和离开过渡

进入过渡:当元素在第一次渲染的时候被插入到 DOM 中时触发。

离开过渡:当元素从 DOM 中移除时触发。

2)过渡类名

v-enter、v-enter-active、v-enter-to:进入过渡时的状态。

v-leave、v-leave-active、v-leave-to:离开过渡时的状态。

3)使用方式

可以通过<transition>或<transition-group>组件来包裹需要过渡的元素或组件。

<transition>用于单个元素的过渡效果,而<transition-group>用于列表元素的过渡效果。

4)钩子函数

before-enter、enter、after-enter等用于在过渡过程的不同阶段执行自定义逻辑。

可以在钩子函数中执行动画、改变状态等操作,以实现更加复杂的过渡效果。

总之:vue中的transition提供了一种简单而灵活的方式来为元素添加过渡效果,使得用户界面更加生动和吸引人。通过合理地运用过渡效果,开发者可以提升用户体验,增强页面交互效果。

面试官:请讲一下你对vue中的diff算法的理解。

我,呃~,vue中的diff算法是通过比较新旧虚拟dom树之间的差异,然后只对变化的部分进行更新,以提高视图更新的效率和性能。通过合理地使用key属性、优化组件级别的diff算法等策略,可以进一步提升Vue应用的性能。

主要原理:在vue内存中维护了一个虚拟dom树,它是对真实dom的一种抽象表示,当数据发生变化时,vue会重新渲染虚拟dom,并生成新的虚拟dom树,vue会比较新旧虚拟dom树之间的差异,找出需要更新的部分,通过深度优先遍历算法,逐层比较新旧节点,找出节点的差异对真正变化的部分进行更新。

diff 算法的时间复杂度是 O(n),其中 n 是节点的数量,算法在大多数情况下表现良好,但在极端情况下(例如树的深度很大),可能会导致性能问题。

面试官:vue通过数据劫持就可以精准探测数据变化,为什么还要进行diff检测差异?

我,呃~,虽然vue使用数据劫持(响应式系统)来实现对数据变化的监测,但是数据劫持仅仅能够检测到数据变化,而无法确定如何将这些变化反映到视图上,以及如何进行最小化的dom更新。因此vue还需要进行 diff 检测差异,以便在数据发生变化时,通过比较新旧虚拟dom树的差异确定需要更新的部分,并且尽可能地减少实际dom操作的数量。

总之:数据劫持是针对数据的变化进行监听,而 diff 检测差异则是针对虚拟dom树的变化进行监听。虽然两者都是为了实现响应式更新,但是数据劫持主要关注数据层面的变化,而 diff 算法主要关注视图层面的变化,两者相辅相成,共同构建了vue的响应式系统。

面试官:请解释一下vue为什么要使用虚拟dom,详细解释一下原理。

我,呃~,vue使用虚拟dom的主要目的是提高性能和开发效率。虚拟dom是对真实dom的一种轻量级的内存表示,通过在内存中操作虚拟dom来实现对真实dom的最小化操作,从而减少dom操作带来的性能开销。

原理:虚拟dom是以js对象的形式存在于内存中的,它包含了真实dom的层次结构以及节点的属性和内容,vue使用虚拟dom可以将多个状态更新操作批量合并成一次更新,从而减少实际dom操作的次数,虽然虚拟dom的创建和比对也会带来一定的性能开销,但是通过优化diff算法,可以将这种开销降到最低。

面试官:请问如果vuex页面刷新数据丢失怎么解决?

我,呃~,当vuex页面刷新导致数据丢失时,这通常是因为vuex中的数据是保存在运行内存中的,页面刷新会重新加载vue实例,从而重置vuex中的数据。为了解决这个问题,可以采用以下几种方法:

1)使用浏览器的本地存储

        使用浏览器的本地存储(如 localStorage 或 sessionStorage)或者客户端数据库(如 IndexedDB)来存储 Vuex 中的数据。在页面加载时,从持久化存储中读取数据并初始化 Vuex 状态。这样可以确保即使页面刷新,数据也能够被恢复。

2)使用vuex持久化插件

        有一些针对 Vuex 的插件可以帮助实现状态的持久化存储,例如 Vuex PersistedState。这些插件可以简化数据的持久化处理,并提供一些额外的功能,如数据加密、自动恢复等。

3)使用后端存储

        数据保存在服务器端,通过网络请求来获取数据。这样即使页面刷新,数据也能够被保留。但这种方法需要考虑网络延迟和服务器性能等因素。

面试官:请叙述一下vue中使用了哪些设计模式?

我,呃~,vue中使用了多种设计模式来实现其功能和特性,其中一些主要的设计模式包括:

1)观察者模式:vue的响应式系统就是基于观察者模式实现的。当数据发生变化时vue能够通知相关的观察者(即依赖于该数据的视图组件),从而实现自动更新视图的功能。

2)发布-订阅模式:在vue中事件总线(Event Bus)和vue实例的事件系统都是基于发布-订阅模式实现的。组件可以订阅特定事件,并在事件触发时执行相应的操作。

3)工厂模式:vue组件的创建过程可以看作是一种工厂模式,即通过组件选项对象来创建具有相同结构和功能的组件实例。

4)单例模式:vue中的全局对象,如vue实例、vue-router和vuex,通常都是单例模式的实现,确保整个应用中只存在一个实例,以便统一管理应用的状态和行为。

5)策略模式:vue的指令(Directives)和过滤器(Filters)可以看作是策略模式的应用,它们允许开发者在不同的场景下选择不同的处理策略,以实现特定的功能和效果。

6)组合模式:vue中的组件树可以看作是组合模式的应用,通过将小的、独立的组件组合成一个更大的、复杂的组件,从而构建出整个应用的界面和功能。

7)代理模式:在vue的数据劫持系统中,使用了代理模式来监听对象的属性访问和修改操作,并在适当的时候触发相应的更新。

这些设计模式使得vue具有灵活、可扩展和易维护的特性,同时也为开发者提供了一种常见的思维模式,有助于更好地理解和使用vue。

面试官:请简述一下vue中的性能优化可以从哪几个方面去思考设计?

我,呃~,在vue中进行性能优化时,可以从以下几个方面去思考设计:

1)减少不必要的渲染:vue的响应式系统会追踪数据的变化,并在数据变化时重新渲染相关的组件。因此可以通过避免不必要的数据变化和组件渲染来提高性能。例如,使用计算属性而不是依赖于模板中的复杂表达式、合理使用 v-if 和 v-show 控制组件的显示与隐藏、避免频繁地改变数组的长度等。

2)优化列表渲染:当渲染大量数据时,vue的列表渲染可能会成为性能瓶颈。可以通过使用 v-for 的key属性、使用v-once缓存静态内容、使用虚拟滚动等技术来优化列表的渲染性能。

3)组件的按需加载:将应用拆分成多个小型组件,并按需加载这些组件,可以减少初始加载时的资源体积和加载时间。可以使用vue-router的懒加载功能或者动态组件来实现组件的按需加载。

4)性能监控和调试:通过使用浏览器的开发者工具和 Vue Devtools 等工具来监控应用的性能指标,识别性能瓶颈并进行优化。可以关注页面的渲染性能、内存占用情况、事件处理性能等方面的指标。

5)服务端渲染(SSR):对于需要更快的首次加载和更好的SEO的应用,可以考虑使用vue的服务端渲染功能。通过在服务端生成首次渲染的 HTML,可以减少客户端渲染所需的时间和资源消耗。

6)代码拆分和懒加载:将应用代码拆分成多个模块,并使用代码分割和懒加载技术来减少初始加载时的资源体积。可以使用webpack的代码分割功能或者动态导入来实现代码的拆分和懒加载。

7)使用合适的第三方库和工具:选择合适的第三方库和工具可以帮助提高应用的性能。例如,使用像 Lodash 这样的工具库来优化数据处理操作、使用像 Axios 这样的 HTTP 库来优化网络请求、使用像 Bundle Analyzer 这样的工具来分析打包结果等。

综合考虑以上方面并根据具体应用的需求和场景进行优化,可以有效地提高vue应用的性能和用户体验。

面试官:nextTick的作用是什么?实现原理是什么?

我,呃~,nextTick的作用是在dom更新完成之后执行延迟任务,在vue中当修改了数据后,vue异步执行dom更新,而nextTick则是在dom更新完成后执行的回调函数,以确保在更新完成后执行特定的操作,如操作更新后的dom或执行其他异步任务。

实现原理:利用浏览器提供的微任务机制,在dom更新完成后执行回调函数,以确保在更新后对dom进行操作或执行其他异步任务:

1)Microtask(微任务):vue使用微任务来实现nextTick,微任务是在当前任务执行结束后立即执行的任务,其优先级高于宏任务(如 setTimeout)。vue利用浏览器提供的微任务机制,在dom更新后插入微任务队列中的任务,从而保证这些任务在dom更新完成后执行。

2)Promise或MutationObserver:在现代浏览器中,vue使用Promise或MutationObserver来实现微任务的调度,Promise提供了一个异步执行的机制,可以在当前任务执行结束后立即执行微任务;MutationObserver则是浏览器提供的一个dom变动的观察者,可以监听dom的变化并在变化发生后执行回调,vue根据浏览器支持的特性选择合适的方式来实现nextTick

3)Fallback(降级处理):对于不支持Promise和MutationObserver的老版本浏览器,vue会降级使用setTimeout来模拟微任务的调度,保证nextTick的功能可以在这些浏览器中正常工作,尽管性能可能会有所下降。

标签:知识点,面试题,Vue,dom,面试官,vue,使用,组件,数据
From: https://blog.csdn.net/qq_53123067/article/details/139381472

相关文章

  • vue3 vite 项目tsx写法尝试
    vite配置上面jsx插件搞好就能在vue项目中使用jsx写法了代码尝试ChildWorld.vue<scriptlang="tsx">import{defineComponent,defineProps}from"vue"constchildAbc=()=>{return(<div>childAbc</div>)}constchildCbd=(props,......
  • 【Vue】深入理解MVVM模式的魔力
    目录前言一、MVVM模式是什么?二、具体示例总结前言    Vue.js是一种基于JavaScript的前端框架,它采用了MVVM(Model-View-ViewModel)模式来实现数据的双向绑定。在本篇博客中,我将介绍MVVM模式的基本概念,并演示如何使用Vue.js来实现这种模式。一、MVVM模式是什么? ......
  • 【Vue】中v-if和v-show的区别到底在哪里?
    概要   Vue.js是一种流行的JavaScript框架,用于构建交互式的Web应用程序。在Vue.js中,v-if和v-show是两个常用的指令,用于控制DOM元素的显示与隐藏。本文将介绍它们之间的区别。整体架构流程   Vue.js的整体架构基于虚拟DOM和响应式数据,当数据发生变化时,Vue会重新......
  • Vue插槽与作用域插槽
    title:Vue插槽与作用域插槽date:2024/6/1下午9:07:52updated:2024/6/1下午9:07:52categories:前端开发tags:VueSlotScopeSlot组件通信Vue2/3插槽作用域API动态插槽插槽优化第1章:插槽的概念与原理插槽的定义在Vue.js中,插槽(Slots)是一种强大的功能,它允许你......
  • 前端面试题日常练-day47 【面试题】
    题目希望这些选择题能够帮助您进行前端面试的准备,答案在文末1.在Bootstrap中,以下哪个类用于创建一个具有响应式的栅格系统?a).grid-systemb).responsive-gridc).container-fluidd).grid-responsive2.哪个Bootstrap类用于创建一个具有圆角边框的按钮?a).btn-rou......
  • Vue-router之页面跳转
    目录1.Vue Router1.1VueRouter的简介1.2安装1.3创建路由器实例2.router-link页面跳转2.1.router-link简介2.2使用路由对象的query属性进行传参1.Vue Router1.1VueRouter的简介官方文档见:https://router.vuejs.org/zh/introduction.htmlhttps://router.v......
  • 基于uniapp+vue+nodejs高校食堂餐厅点餐系统2x2v4 小程序hbuilderx
    近年来,我国餐饮业发展的质量和内涵发生了重大的变化。行业的经营领域和市场空间不断变化,经营档次和企业管理水平不断提高,经营业态日趋丰富,投资主体和消费需求多元化特点更加突出,网点数量和人员队伍继续扩大;餐饮市场更加繁荣,消费的个性化和特色化的趋势明显,追求健康营养和连锁规......
  • vue3随笔
    vite:相比webpack webpack先通过入口文件找依赖 然后打包bounder然后启动devServervite 直接启动devServer然后找依赖模块由浏览器去请求本地服务返回依赖模块项目越多模块越大vite越好效率提升静态提升 静态节点 没有动态绑定的内容会提升到render函......
  • vue3 && uni-app 中小程序实现 底部tabbar 中间凸起部分 或者说自定义底部tabbar [保
    1、先来看一下效果2、代码实现 我们还是在pages.json 中正常配置我们底部的tabbar但是需要添加一个字段 "custom":true,//开启自定义tabBar 不填每次原来的tabbar在重新加载时都回闪现3、在pages同一级或者里面创建一个子组件用来放我们的模版 4、在......
  • Vue3的自动化测试怎么做?详细说明一下常用的测试工具和框架
    随着前端技术的飞速发展,Vue3作为一个优秀的前端框架,已经广泛应用于各类项目中。在开发过程中,为了提升代码质量、减少运维成本,自动化测试变得尤为重要。不仅可以提高开发效率,还能确保产品的稳定性。那么,Vue3自动化测试该怎么做呢?本文将详细介绍常用的测试工具和框架。为......