Vue面试题合集

vue.js

一. 请谈谈Vue中的MVVM模式

MVVM全称是Model-View-ViewModel
Vue是以数据为驱动的,Vue自身将DOM和数据进行绑定,一旦建立绑定,DOM和数据将保持同步,每当数据发生变化,DOM会跟着变化。 ViewModel是Vue的核心,它是Vue的一个实例。Vue实例时做用域某个HTML元素上的这个HTML元素能够是body,也能够是某个id所指代的元素。
DOMListeners和DataBindings是实现双向绑定的关键。DOMListeners监听页面全部View层DOM元素的变化,当发生变化,Model层的数据随之变化;DataBindings监听Model层的数据,当数据发生变化,View层的DOM元素随之变化。html

二. v-showv-if指令的共同点和不一样点?

v-show指令是经过修改元素的display CSS属性让其显示或者隐藏vue

v-if指令是直接销毁和重建DOM达到让元素显示和隐藏的效果vuex

三. 如何让CSS只在当前组件中起做用?

将当前组件的<style>修改成<style scoped>缓存

四. <keep-alive></keep-alive>的做用是什么?

<keep-alive></keep-alive> 包裹动态组件时,会缓存不活动的组件实例,主要用于保留组件状态或避免从新渲染。
大白话: 好比有一个列表和一个详情,那么用户就会常常执行打开详情=>返回列表=>打开详情…这样的话列表和详情都是一个频率很高的页面,那么就能够对列表组件使用<keep-alive></keep-alive>进行缓存,这样用户每次返回列表的时候,都能从缓存中快速渲染,而不是从新渲染框架

五. Vue中引入组件的步骤?

1.采用ES6的import ... from ...语法或CommonJS的require()方法引入组件
2.对组件进行注册,代码以下异步

// 注册
Vue.component('my-component', {
  template: '<div>A custom component!</div>'
})

3.使用组件<my-component></my-component>ide

六. 指令v-el的做用是什么?

提供一个在页面上已存在的 DOM 元素做为 Vue 实例的挂载目标.能够是 CSS 选择器,也能够是一个 HTMLElement 实例,函数

七. 在Vue中使用插件的步骤

采用ES6的import ... from ...语法或CommonJSd的require()方法引入插件
使用全局方法Vue.use( plugin )使用插件,能够传入一个选项对象Vue.use(MyPlugin, { someOption: true })ui

八. 请列举出3个Vue中经常使用的生命周期钩子函数?

created: 实例已经建立完成以后调用,在这一步,实例已经完成数据观测, 属性和方法的运算, watch/event事件回调. 然而, 挂载阶段尚未开始, $el属性目前还不可见spa

mounted: el被新建立的 vm.$el 替换,并挂载到实例上去以后调用该钩子。若是 root 实例挂载了一个文档内元素,当 mounted 被调用时 vm.$el 也在文档内。

activated::keep-alive组件激活时调用

九. 请简述下Vuex的原理和使用方法

数据单向流动

一个应用能够看做是由上面三部分组成: View, Actions,State,数据的流动也是从View => Actions => State =>View 以此达到数据的单向流动.可是项目较大的, 组件嵌套过多的时候, 多组件共享同一个State会在数据传递时出现不少问题.Vuex就是为了解决这些问题而产生的.
Vuex能够被看做项目中全部组件的数据中心,咱们将全部组件中共享的State抽离出来,任何组件均可以访问和操做咱们的数据中心.

Vuex原理

上图能够很好的说明Vuex的组成,一个实例化的Vuex.Store由state, mutations和actions三个属性组成:

  • state中保存着共有数据
  • 改变state中的数据有且只有经过mutations中的方法,且mutations中的方法必须是同步的
  • 若是要写异步的方法,须要些在actions中, 并经过commit到mutations中进行state中数据的更改.

更多Vuex信息,请参考Vuex官网 : vuex.vuejs.org

十. 请谈谈Vue框架和Angular.js和React的不一样

参见:Vue对比其余框架

相关文章
相关标签/搜索