Vue面试题
Vue
简述下MVVM
MVVM全称是MODEL-VIEW-VIEWMODEL
Vue是以数据为驱动,Vue自身将DOM和数据进行绑定,一旦创建绑定,DOM和数据将保持同步,当数据发生变化,DOM也会发生变化
ViewModel是Vue的核心,它是Vue实例。Vue实例的作用域是某个HTML元素
DOMListeners和DataBindings是实现数据双向绑定的关键
DOMListeners监听View层DOM的变化,当发生变化,则Model的数据发生变化
DataBindings监听Model层的数据变化,当数据变化,则View层中DOM发生变化
什么是虚拟DOM
虚拟DOM是Vue和React的核心
它的本质是通过JS模拟DOM树
也就是DOM发生变化时放在JS层来操作,因为操作DOM代价很大。
虚拟DOM不会立即操作浏览器DOM,提升浏览器的性能
Vue的生命周期
开始创建-编译模板-挂载DOM- 渲染-更新-渲染 beforeCreat在实例初始化之后,此刻data和el是undefined
created实例创建完成,完成了data的初始化,el还是为undefined
beforeMounted挂载之前调用,完成data和el的初始化,把data和模板生成虚拟DOM,还没挂载到HTML中
mounted挂载完成,把虚拟DOM渲染到真实的DOM中,此时可以ajax操作
beforeUpdate,update数据data变化时候自动执行的钩子函数
beforeDestroy
destroyed 组件销毁时自动执行的钩子函数,主要执行定时器销毁等操作
简单概述下keep-alive,需要注意哪些问题
包囊动态组件,起到缓存作用,防止路由跳转发送额外服务器请求重新渲染页面
注意问题:、每次进入新页面时,需要activated判断是否向服务器请求数据。、exclude 匹配的组件都不会缓存,exclude=‘组件名’
什么是计算属性和方法调用有什么区别
模板内使用表达式非常方便,但是只能用于简单运算,而且计算属性可以完成复杂的逻辑运算。
计算属性只要依赖的数据发生变化时就会重新计算,具有缓存功能
而且方法调用在每次render之后都会执行,不具备缓存功能
v-if和v-show的区别
v-if和v-show是隐藏元素的
v-if是真正的条件渲染,也就是说销毁创建DOM让元素隐藏显示
v-show是通过display的css来控制隐藏显示
vue常用的修饰符
.lazy
.number
.trim
事件修饰符
stop/prevemt/capture/self/once/passive
按键修饰符
keyup.enter/tab/delete/esc/space/up/down/left/right
v-on可以监听多个方法吗
可以
<input @input @blur @focus />
vue中的key值作用
提供key来给每个节点做一个唯一标识,Diff算法正确的识别此节点,找到正确的位置重新渲染
key的主要作用是提高虚拟DOM的渲染
Vue组件中data为什么必须是函数
这样每个实例的data都是独立的,不会相互影响,这是js本身特性带来的。
返回唯一的对象,保证组件间数据不会互相影响
Vue组件间如何传值
父-子 通过prop
子-父 通过$emit
组件间使用vuex
更新数组触发视图更新的方法有哪些
数组的变异方法
push/pop/shift/unshift/sort/splice/reverse
Vue中对象更改检测的注意事项
Vue无法检测以下发生变化的数组
、利用索引直接设置一个项 vm.item[index] = value
、修改数组长度 vm.item.length = newLength
对象更改注意事项
、Vue无法检测到对象的属性添加删除 解决方案
、Vue.set(vm.items,index,newValue) / vm.items.splice(index, , newValue)
、vm.items.splice(newLength)
、Vue.set(object, key, value) / vm.$set(object, key, value)
Vue单页面的优缺点
优点:
无刷新,提升用户体验
完全的前端组件化
缺点:
SEO差
首屏加载慢
scoped的作用
CSS只能在当前组件中起作用
mixin
主要作用是实现组件间 数据和方法的复用
Vuex
手写一个vuex
import Vue from 'vue'
import Vuex from 'Vuex'
Vue.use(Vuex) const state = { count : } const mutations = { 'SET_COUNT': (state, count) => { state.count=count } } const actions = { setCount: ({commit}, count) => (commit('SET_COUNT'), count } const store = new Vuex.Store({
state,
mutations,
actions
}) export default store
Vuex是什么
主要作用是存储组件间的数据状态
State:Vuex中的单一状态树,一个应用只有一个store
Getter:跟计算属性一样,返回的值根据它的依赖缓存起来,只要它的依赖发生改变时才会重新计算
Mutations:同步的,而且时唯一改变store数据的地方
Actions:异步的,不能直接修改store中的数据,只能提交给mutation
Module:将store分割成模块,每个模块有自己的state,mutations,actions
使用场景
单页面应用/音乐播放器/登录状态/购物车
Vuex模块化如何实现,组件如何引用
Vue-Router
手写一个vue-router
、定义组件 或者import
Const Foo ={template:‘<div> foo</div>’ }
Const Bar ={template:‘<div> bar</div>’ }
、定义路由 每个路由映射一个组件
Const routes = [
{path:’/foo’,component:Foo},
{path:’/bar,component: Bar },
]
、创建ruoter实例
Const router = new VueRouter({routers})
、挂载
Const app = new Vue({
router}).$mount(‘#app’)
动态路由如何书写,组件如何接受动态路由参数
动态路由以冒号开头
Const routes=[{path:’/user/:id’,component:User},]
可以通过this.$route.params.id获取到
Vue面试题的更多相关文章
- 2019前端面试系列——Vue面试题
Vue 双向绑定原理 mvvm 双向绑定,采用数据劫持结合发布者-订阅者模式的方式,通过 Object.defineProperty()来劫持各个属性的 setter.getter,在数 ...
- php开发面试题---vue面试题(vue.js的好处及作用)
php开发面试题---vue面试题(vue.js的好处及作用) 一.总结 一句话总结: 双向数据绑定:在做ajax的时候,更新实在是太方便了 用数据绑定的思想,vue可以简单写单个页面,也可以写一个大 ...
- Vue 面试题汇总
Vue 面试题汇总 refs xgqfrms 2012-2020 www.cnblogs.com 发布文章使用:只允许注册用户才可以访问!
- 【前端面试】Vue面试题总结(持续更新中)
Vue面试题总结(持续更新中) 题目参考链接 https://blog.csdn.net/weixin_45257157/article/details/106215158 由于已经有很多前辈深造VU ...
- 法门扫地僧总结vue面试题(部分来源网络)
Front-End 前端开发工程师面试宝典! (本文部分有转载,不定期更新!) 前言(README.md) 本仓库是我整理的前端常见面试题,大部分由我整理,其中个别部分参考 ...
- Vue面试题整理
1:什么是MVVM MVVM是是Model-View-ViewModel的缩写,Model代表数据模型,定义数据操作的业务逻辑,View代表视图层,负责将数据模型渲染到页面上,ViewModel通过双 ...
- vue面试题总汇
active-class是哪个组件的属性? vue-router模块的router-link组件. 嵌套路由怎么定义? 在实际项目中我们会碰到多层嵌套的组件组合而成,但是我们如何实现嵌套路由呢?因此我 ...
- vue面试题!!!
由于公司需要,需要把项目拆分,前端使用vue框架.最近面试vue总结的试题 1:mvvm框架是什么?它和其他框架的区别是什么? mvvm 全称model view viewModel,model数据模 ...
- 本人编写的一份前端vue面试题
说明,此题目本人自出,做过本人所在公司的前端面试题,在此共享给大家 1. 如何在vue组件中实现v-model的功能?(只需给出关键代码) 2. 简述你知道的生命周期函数和执行时机 3. 谈谈你对计算 ...
- vue面试题,知识点汇总(有答案)
一. Vue核心小知识点 1.vue中 key 值的作用 key 的特殊属性主要用在 Vue的虚拟DOM算法,在新旧nodes对比时辨识VNodes.如果不使用key,Vue会使用一种最大限度减少动态 ...
随机推荐
- MapServer Tutorial——MapServer7.2.1教程学习——第一节用例实践:Example1.1 A map with single layer
MapServer Tutorial——MapServer7.2.1教程学习——第一节用例实践:Example1.1 A map with single layer 一.前言 开始MapServer用 ...
- jdk安装环境变量配置
v\:* {behavior:url(#default#VML);} o\:* {behavior:url(#default#VML);} w\:* {behavior:url(#default#VM ...
- jQuery键盘敲击事件,换键的话换键码就可以
$("body").keyup(function () { if (event.which == 13){ $("#Btn_login").trigger(&q ...
- 大数据面试题——如何从大量的url中找出相同的url
题目描述: 给定a.b两个文件,各存放50亿个url,每个url各占64B,内存限制是4GB,请找出a.b两个文件共同的url 分析: 由于每个url需要占64B,所以50亿个url占用空间大小为50 ...
- python中如何删除列表中的所有元素
今天写代码的时候遇到一个小问题,Python中要删除列表中的所有元素.Python本身就提供了pop.remove.del这些删除的函数.我想着用循环实现,结果很麻烦.几番周折上了stackoverf ...
- python变量进阶(可变不可变,局部变量和全局变量)
变量进阶(理解) 目标 变量的引用 可变和不可变类型 局部变量和全局变量 01. 变量的引用 变量 和 数据 都是保存在 内存 中的 在 Python 中 函数 的 参数传递 以及 返回值 都是靠 引 ...
- 剑指Offer 48. 不用加减乘除做加法 (其他)
题目描述 写一个函数,求两个整数之和,要求在函数体内不得使用+.-.*./四则运算符号. 题目地址 https://www.nowcoder.com/practice/59ac416b4b944300 ...
- AFN\HTTPS\UIWebView
1.AFN使用技巧 1.在开发的时候可以创建一个工具类,继承自我们的AFN中的请求管理者,再控制器中真正发请求的代码使用自己封装的工具类. 2.这样做的优点是以后如果修改了底层依赖的框架,那么我们修改 ...
- net core 解除上传大附件的限制
1.对于使用自带服务器kernal的情况下,只需要在对应的action上添加属性 DisableRequestSizeLimit [HttpPost] [DisableRequestSizeLimit ...
- Python 学习之路的前言
做为一个编程小白,除了大三的时候考了VB的二级之后,就在也没有接触过其它有关计算机之类的知识.考入材料的研究生之后,越来越觉得自己不想继续这个行业,选择计算机作为自己以后要走的路,所下的决心所用的时间 ...