vue面试

资料来源:https://blog.csdn.net/qq_44182284/article/details/111191455

 

Vue常见面试题

    Vue的优点
    说说你对SPA单页面的理解,它的优缺点分别是什么?
    SPA首屏加载速度慢的怎么解决?
    Vue初始化过程中(new Vue(options))都做了什么?
    对MVVM的理解?
    Vue数据双向绑定原理
    Vue的响应式原理
    Vue3.x响应式数据原理
    Vue3.0 里为什么要用 Proxy API替代 defineProperty API?
    Proxy 与 Object.defineProperty 优劣对比
    vue中组件的data为什么是一个函数?而new Vue 实例里,data 可以直接是一个对象
    vue中data的属性可以和methods中方法同名吗,为什么?
    vue中created与mounted区别
    Vue中computed与method的区别
    虚拟DOM中key的作用
    用index作为key可能会引发的问题
    Vue中watch用法详解
    vue中对mixins的理解和使用
    vue中的插槽
    为什么vue采用异步渲染
    Vue 的异步更新机制是如何实现的?
    $nextTick的理解
    Vue中常用的一些指令
    vue的自定义指令
    你有写过自定义指令吗?自定义指令的应用场景有哪些?
    v-show和v-if指令的共同点和不同点
    为什么避免v-if和v-for一起使用
    vue为什么在 HTML 中监听事件?
    Vue.set 改变数组和对象中的属性
    vm.$set(obj, key, val) 做了什么?
    说说vue的生命周期的理解
    第一次页面加载会触发哪几个钩子?
    Vue组件通信有哪些方式
    router和route的区别
    vue-router有几种钩子函数?
    vue-router路由跳转方式
    vue-router路由传参
    keep-alive了解吗
    Vuex是什么?怎么使用?
    什么情况下使用 Vuex?
    Vuex和单纯的全局对象有什么区别?
    为什么 Vuex 的 mutation 中不能做异步操作?
    axios 是什么,其特点和常用语法
    对SSR有了解吗,它主要解决什么问题?
    Vue要做权限管理该怎么做?控制到按钮级别的权限怎么做?
    Vue项目前端开发环境请求服务器接口跨域问题
    做过哪些Vue的性能优化?
    Vue3有了解过吗?能说说跟Vue2的区别吗?
    Vue 3.0 所采用的 Composition Api 与 Vue 2.x使用的Options Api 有什么区别?
    element-ui中遇到的问题

Vue的优点

    轻量级框架:只关注视图层,是一个构建数据的视图集合,大小只有几十 kb ;
    简单易学:国人开发,中文文档,不存在语言障碍 ,易于理解和学习;
    双向数据绑定:保留了 angular 的特点,在数据操作方面更为简单;
    组件化:保留了 react 的优点,实现了 html 的封装和重用,在构建单页面应用方面有着独特的优势;
    视图,数据,结构分离:使数据的更改更为简单,不需要进行逻辑代码的修改,只需要操作数据就能完成相关操作;
    虚拟DOM:dom 操作是非常耗费性能的, 不再使用原生的 dom 操作节点,极大解放 dom 操作,但具体操作的还是 dom 不过是换了另一种方式;
    运行速度更快:相比较于 react 而言,同样是操作虚拟 dom ,就性能而言, vue 存在很大的优势。

说说你对SPA单页面的理解,它的优缺点分别是什么?

是什么

    SPA( single page application )仅在 Web 页面初始化时加载相应的 HTML、JavaScript 和 CSS。
    一旦页面加载完成,SPA 不会因为用户的操作而进行页面的重新加载或跳转
    而页面的变化是利用路由机制实现 HTML 内容的变换,避免页面的重新加载。

优点

    用户体验好,内容的改变不需要重新加载整个页面,避免了不必要的跳转和重复渲染
    减少了不必要的跳转和重复渲染,这样相对减轻了服务器的压力
    前后端职责分离,架构清晰,前端进行交互逻辑,后端负责数据处理

缺点

    初次加载耗时多
    不能使用浏览器的前进后退功能,由于单页应用在一个页面中显示所有的内容,所以,无法前进后退
    不利于搜索引擎检索:由于所有的内容都在一个页面中动态替换显示,所以在 SEO 上其有着天然的弱势。

SPA首屏加载速度慢的怎么解决?

首屏时间(First Contentful Paint),指的是浏览器从响应用户输入网址地址,到首屏内容渲染完成的时间,此时整个网页不一定要全部渲染完成,但需要展示当前视窗需要的内容;

加载慢的原因

    网络延时问题
    资源文件体积是否过大
    资源是否重复发送请求去加载了
    加载脚本的时候,渲染内容堵塞了

常见的几种SPA首屏优化方式

    减小入口文件积
    静态资源本地缓存
    UI框架按需加载
    图片资源的压缩
    组件重复打包
    开启GZip压缩
    使用SSR

想要具体了解可以点击SPA(单页应用)首屏加载速度慢的解决详解
Vue初始化过程中(new Vue(options))都做了什么?

    处理组件配置项;初始化根组件时进行了选项合并操作,将全局配置合并到根组件的局部配置上;初始化每个子组件时做了一些性能优化,将组件配置对象上的一些深层次属性放到 vm.$options 选项中,以提高代码的执行效率;
    初始化组件实例的关系属性,比如 p a r e n t 、 parent、 parent、children、 r o o t 、 root、 root、refs 等
    处理自定义事件
    调用 beforeCreate 钩子函数
    初始化组件的 inject 配置项,得到 ret[key] = val 形式的配置对象,然后对该配置对象进行响应式处理,并代理每个 key 到 vm 实例上
    数据响应式,处理 props、methods、data、computed、watch 等选项
    解析组件配置项上的 provide 对象,将其挂载到 vm._provided 属性上
    调用 created 钩子函数
    如果发现配置项上有 el 选项,则自动调用 $mount 方法,也就是说有了 el 选项,就不需要再手动调用 $mount 方法,反之,没提供 el 选项则必须调用 $mount
    接下来则进入挂载阶段

posted @ 2022-06-27 11:07  Haoyin-杰克  阅读(29)  评论(0编辑  收藏  举报