vue.js面试笔记

一、react和vue有哪些不一样,说说你对这两个框架的见解

相同点css

  • 都支持服务器端渲染
  • 都有Virtual DOM,组件化开发,经过props参数进行父子组件数据的传递,都实现webComponent规范
  • 数据驱动视图
  • 都有支持native的方案,React的React native,Vue的weex

不一样点html

  • React严格上只针对MVC的view层,Vue则是MVVM模式
  • virtual DOM不同,vue会跟踪每个组件的依赖关系,不须要从新渲染整个组件树.而对于React而言,每当应用的状态被改变时,所有组件都会从新渲染,因此react中会须要shouldComponentUpdate这个生命周期函数方法来进行控制
  • 组件写法不同, React推荐的作法是 JSX + inline style,也就是把HTML和CSS全都写进JavaScript了,即'all in js'; Vue推荐的作法是webpack+vue-loader的单文件组件格式,即html,css,jd写在同一个文件;
  • 数据绑定: vue实现了数据的双向绑定,react数据流动是单向的
  • state对象在react应用中不可变的,须要使用setState方法更新状态;在vue中,state对象不是必须的,数据由data属性在vue对象中管理

2.MVC和MVVM的区别

MVC(Model-View-Controller)前端

  • MVC是比较直观的架构模式,用户操做->View(负责接收用户的输入操做)->Controller(业务逻辑处理)->Model(数据持久化)->View(将结果反馈给View)。
  • MVC使用很是普遍,好比JavaEE中的SSH框架

MVVM(Model-View-ViewModel)vue

  • 若是说MVP是对MVC的进一步改进,那么MVVM则是思想的彻底变革。它是将“数据模型数据双向绑定”的思想做为核心,所以在View和Model之间没有联系,经过ViewModel进行交互,并且Model和ViewModel之间的交互是双向的,所以视图的数据的变化会同时修改数据源,而数据源数据的变化也会当即反应view。

如何理解vue中MVVM模式?react

  • MVVM全称是Model-View-ViewModel;vue是以数据为驱动的,一旦建立dom和数据就保持同步,每当数据发生变化时,dom也会变化。
  • DOMListeners和DataBindings是实现双向绑定的关键。DOMListeners监听页面全部View层DOM元素的变化,当发生变化,Model层的数据随之变化;DataBindings监听Model层的数据,当数据发生变化,View层的DOM元素随之变化。

三、vue的虚拟dom?

  • 虚拟的DOM的核心思想是:对复杂的文档DOM结构,提供一种方便的工具,进行最小化地DOM操做。
  • 简单来讲,虚拟DOM是用Object来表明一颗节点,这个Object叫作VNode,而后使用两个VNode进行对比,根据对比后的结果修改真实DOM。
  • 为何是两个VNode?由于每次渲染都会生成一个新的VNode,而后和上一次渲染时用的VNode进行对比。而后将这一次新生成的VNode缓存,用来进行下一次对比。

四、说出至少4种vue当中的指令和它的用法?

  • v-if:是“真正”的条件渲染,在切换中组件会适当的被销毁和重建;
  • v-for:数据循环渲染;
  • v-show:控制元素的显示隐藏,即控制元素的display,基于 CSS 进行切换
  • v-bind:class:绑定一个属性;
  • v-model:实现双向绑定

五、组件之间的传值通讯?

  • 父组件向子组件传值,经过props
//父组件经过标签上面定义传值
    <template>
        <Main :obj="data"></Main>
    </template>
    <script>
        //引入子组件
        import Main form "./main"
        
        exprot default{
            name:"parent",
            data(){
                return {
                    data:"我要向子组件传递数据"
                }
            },
            //初始化组件
            components:{
                Main
            }
        }
    </script>
//子组件经过props方法接受数据
     
    <template>
        <div>{{data}}</div>
    </template>
    <script>
        exprot default{
            name:"son",
            //接受父组件传值
            props:["data"]
        }
    </script>
  • 子组件向父组件传值:经过$on,$emitwebpack

    1. 子组件中须要以某种方式(如点击事件)的方法来触发一个自定义的事件;
    2. 将须要传的值做为$emit的第二个参数,该值将做为实参传给响应事件的方法;
    3. 在父组件中注册子组件并在子组件标签上绑定自定义事件的监听。
//子组件:
<template>
    <div @click="up"></div>
</template>

methods: {
    up() {
        this.$emit('upup','hehe'); //主动触发upup方法,'hehe'为向父组件传递的数据
    }
}

//父组件
<div>
    <child v-on:upup="change" :msg="msg"></child> //监听子组件触发的upup事件,而后调用change方法
</div>
methods: {
    change(msg) {
        this.msg = msg;
    }
}
  • 非父子组件通讯

若是2个组件不是父子组件那么如何通讯呢?这时能够经过eventHub来实现通讯.
所谓eventHub就是建立一个事件中心,至关于中转站,能够用它来传递事件和接收事件.angularjs

let Hub = new Vue(); //建立事件中心

//组件1触发:
<div @click="eve"></div>
methods: {
    eve() {
        Hub.$emit('change','hehe'); //Hub触发事件
    }
}

//组件2接收:
<div></div>
created() {
    Hub.$on('change', () => { //Hub接收事件
        this.msg = 'hehe';
    });
}

六、vue的优势是什么?

  • 低耦合。视图(View)能够独立于Model变化和修改,一个ViewModel能够绑定到不一样的"View"上,当View变化的时候Model能够不变,当Model变化的时候View也能够不变。
  • 可重用性。你能够把一些视图逻辑放在一个ViewModel里面,让不少view重用这段视图逻辑。
  • 独立开发。开发人员能够专一于业务逻辑和数据的开发(ViewModel),设计人员能够专一于页面设计,使用Expression Blend能够很容易设计界面并生成xml代码。
  • 可测试。界面素来是比较难于测试的,而如今测试能够针对ViewModel来写。

七、路由之间跳转?

  • 声明式(标签跳转) <router-link :to="index">es6

  • 编程式(js跳转) router.push('index')

八、组件的使用和本身建立公用组件?

  • 第一步:在components目录新建你的组件文件(indexPage.vue),script必定要export default {}
  • 第二步:在须要用的页面(组件)中导入:import indexPage from '@/components/indexPage.vue'
  • 第三步:注入到vue的子组件的components属性上面,components:{indexPage}
  • 第四步:在template视图view中使用,

问题有indexPage命名,使用的时候则index-pageweb

九、vue如何实现按需加载配合webpack设置?

  • webpack中提供了require.ensure()来实现按需加载。之前引入路由是经过import 这样的方式引入,改成const定义的方式进行引入。
  • 不进行页面按需加载引入方式:import home from '../../common/home.vue'
  • 进行页面按需加载的引入方式:const home = r => require.ensure( [], () => r (require('../../common/home.vue')))

十、vuex是什么?怎么使用?哪一种功能场景使用它?

  • vue框架中状态管理。在main.js引入store,注入。场景有:单页应用中,组件之间的状态。音乐播放、登陆状态、加入购物车
  • 数据单向流动vue-router

    1. 一个应用能够看做是由上面三部分组成: View, Actions,State,数据的流动也是从View => Actions => State =>View,以此达到数据的单向流动,可是项目较大的,组件嵌套过多的时候,多组件共享同一个State会在数据传递时出现不少问题。Vuex就是为了解决这些问题而产生的。
    2. Vuex能够被看做项目中全部组件的数据中心,咱们将全部组件中共享的State抽离出来,任何组件均可以访问和操做咱们的数据中心。
    3. Vuex的组成,一个实例化的Vuex.Storestate, mutationsactions三个属性组成:state中保存着共有数据,改变state中的数据只能经过mutations中的方法,且mutations中的方法必须是同步的,若是要写异步的方法,须要些在actions中,并经过commitmutations中进行state中数据的更改。

十一、v-show和v-if指令的共同点和不一样点?

  • v-show指令是经过修改元素的displayCSS属性让其显示或者隐藏
  • v-if指令是直接销毁和重建DOM达到让元素显示和隐藏的效果

十二、如何让CSS只在当前组件中起做用?

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

1三、<keep-alive></keep-alive>的做用是什么?

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

1四、Vue中引入组件的步骤?

  • 采用ES6的import ... from ...语法或CommonJSrequire()方法引入组件
  • 对组件进行注册,代码以下
// 注册
Vue.component('my-component', {
  template: '<div>A custom component!</div>'
})
  • 3.使用组件<my-component></my-component>

1五、指令v-el的做用是什么?

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

1六、在Vue中使用插件的步骤

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

1七、vue-loader是什么?使用它的用途有哪些?

  • 解析.vue文件的一个加载器,将template/js/style转换成js模块。
  • 用途:js能够写es六、style样式能够scss或less、template能够加jade等

1八、请说出vue.cli项目中src目录每一个文件夹和文件的用法?

  • assets文件夹是放静态资源;
  • components是放组件;
  • router是定义路由相关的配置;
  • view视图;
  • app.vue是一个应用主组件;
  • main.js是入口文件

1九、聊聊你对Vue.js的template编译的理解?

  • 简而言之,就是先转化成AST树,再获得的render函数返回VNode(Vue的虚拟DOM节点)
  • 详情步骤:
    首先,经过compile编译器把template编译成AST语法树(abstract syntax tree 即 源代码的抽象语法结构的树状表现形式),compile是createCompiler的返回值,createCompiler是用以建立编译器的。另外compile还负责合并option。

    而后,AST会通过generate(将AST语法树转化成render funtion字符串的过程)获得render函数,render的返回值是VNode,VNode是Vue的虚拟DOM节点,里面有(标签名、子节点、文本等等)

20、vue-router的两种模式的区别

前端路由的核心,就在于 —— 改变视图的同时不会向后端发出请求。

  • hash —— 即地址栏 URL 中的 # 符号(此 hash 不是密码学里的散列运算)。
    好比这个 URL:http://www.abc.com/#/hello,hash 的值为 #/hello。它的特色在于:hash 虽然出如今 URL 中,但不会被包括在 HTTP 请求中,对后端彻底没有影响,所以改变 hash 不会从新加载页面。
  • history —— 利用了 HTML5 History Interface 中新增的 pushState() 和 replaceState() 方法。(须要特定浏览器支持)
    这两个方法应用于浏览器的历史记录栈,在当前已有的 back、forward、go 的基础之上,它们提供了对历史记录进行修改的功能。只是当它们执行修改时,虽然改变了当前的 URL,但浏览器不会当即向后端发送请求。

所以能够说,hash 模式和 history 模式都属于浏览器自身的特性,Vue-Router 只是利用了这两个特性(经过调用浏览器提供的接口)来实现前端路由。

2一、vuejs与angularjs以及react的区别?

  • 与AngularJS的区别
    相同点:
    1.都支持指令:内置指令和自定义指令。
    2.都支持过滤器:内置过滤器和自定义过滤器。
    3.都支持双向数据绑定。
    4.都不支持低端浏览器。
    不一样点:
    1.AngularJS的学习成本高,好比增长了Dependency Injection特性,而Vue.js自己提供的API都比较简单、直观。
    2.在性能上,AngularJS依赖对数据作脏检查,因此Watcher越多越慢。
    3.Vue.js使用基于依赖追踪的观察而且使用异步队列更新。全部的数据都是独立触发的。对于庞大的应用来讲,这个优化差别仍是比较明显的。

  • 与React的区别
    相同点:
    1.React采用特殊的JSX语法,Vue.js在组件开发中也推崇编写.vue特殊文件格式,对文件内容都有一些约定,二者都须要编译后使用。
    2.中心思想相同:一切都是组件,组件实例之间能够嵌套。
    3.都提供合理的钩子函数,可让开发者定制化地去处理需求。
    4.都不内置列数AJAX,Route等功能到核心包,而是以插件的方式加载。
    5.在组件开发中都支持mixins的特性。
    不一样点:
    1.React依赖Virtual DOM,而Vue.js使用的是DOM模板。React采用的Virtual DOM会对渲染出来的结果作脏检查。
    2.Vue.js在模板中提供了指令,过滤器等,能够很是方便,快捷地操做DOM。

2二、请详细说下你对vue生命周期的理解?

  • 总共分为8个阶段建立前/后,载入前/后,更新前/后,销毁前/后。
    建立前/后: 在beforeCreate阶段,vue实例的挂载元素el和数据对象data都为undefined,还未初始化。在created阶段,vue实例的数据对象data有了,el尚未。

    载入前/后:在beforeMount阶段,vue实例的$eldata都初始化了,但仍是挂载以前,为虚拟的dom节点,data.message还未替换。在mounted阶段,vue实例挂载完成,data.message成功渲染。

    更新前/后:当data变化时,会触发beforeUpdateupdated方法。

    销毁前/后:在执行destroy方法后,对data的改变不会再触发周期函数,说明此时vue实例已经解除了事件监听以及和dom的绑定,可是dom结构依然存在

2三、什么是vue生命周期?

  • Vue 实例从建立到销毁的过程,就是生命周期。也就是从开始建立、初始化数据、编译模板、挂载Dom→渲染、更新→渲染、卸载等一系列过程,咱们称这是 Vue 的生命周期。

2四、vue生命周期的做用是什么?

  • 借助组件各个阶段的钩子能够对组件有更好的利用和扩展。

2五、第一次页面加载会触发哪几个钩子?

  • 会触发 beforeCreate, created, beforeMount, mounted 这几个钩子

2六、DOM 渲染在 哪一个周期中就已经完成?

  • DOM 渲染在 mounted 中就已经完成了

2七、简单描述每一个周期具体适合哪些场景?

  • 生命周期钩子的一些使用方法:
    beforecreate : 能够在这加个loading事件,在加载实例时触发
    created : 初始化完成时的事件写在这里,如在这结束loading事件,异步请求也适宜在这里调用
    mounted : 挂载元素,获取到DOM节点
    updated : 若是对数据统一处理,在这里写上相应函数
    beforeDestroy : 能够作一个确认中止事件的确认框
    nextTick : 更新数据后当即操做dom