猿吟鹤唳本无意,不知下有行人行

vue了解

1、对于MVVM的理解

MVVM是Model View iewModel的缩写。

Model代表数据模型,也可以在model中定义数据修改和操作的业务逻辑。

view代表视图UI组件,它负责将数据模型转化为视图展现出来

viewModel监听模型数据的改变和控制视图行为、处理用户交互。连接view和model的,同步之间的对象,建立连接。

在MVVM架构下,view和model之间并没有直接的联系,而是通过viewModel进行交互,model和viewModel之间的交互式双向的,因此view数据变化会同步到model中,二model数据的变化也会立即反映到view上。

viewModel通过双向数据绑定把view层和model层连接了起来,而view和model之间的同步工作完全是自动的,无需人为干涉,因此开发者只需要关注业务逻辑,不需要手动操作DOM,不需要关注数据状态的同步问题,复杂的数据状态维护完全由MVVM来统一管理。

2、VUE的生命周期

beforeCreate(创建前) 在数据观测和初始化事件还未开始
created(创建后) 完成数据观测,属性和方法的运算,初始化事件,$el属性还没有显示出来
beforeMount(载入前)在挂在开始之前被调用,线管的render函数首次被调用。实例已完成以下的配置:编译模板,把data的数据和模板生成HTML。注意此时还没有挂载HTML在页面上
mounted(载入后)在el被创建的vm.$el替换,并挂载到实力上去后调用。实例已完成以下的配置:用上面编译好的html渲染到html内容替换el属性指向的DOM对象。完成模板中的html渲染到html页面中。此过程中进行ajax的交互。
beforeUpdate(更新前)在数据更显之前调用,发生在虚拟DOM重新渲染和打补丁之前。可以在该钩子中进一步地更改状态,不会触发附加的重渲染过程。
update(更新后)在由于数据更改导致的虚拟DOM重新渲染和打补丁之后调用。调用时,组件DOM已经更新,所以可以执行依赖于DOM的操作。然而在大多数情况下,应该避免在此期间更改状态,因为这可能会导致更新无限循环。该钩子在服务端渲染期间不被调用。
beforeDestory(销毁前)在实例销毁之前调用。实例仍然完全可用。
destroyed(销毁后)在实例销毁之后调用。调用后,所有的事件监听器会被移除,所有的子实例也会被销毁。该钩子在服务器渲染期间不被调用。

①什么是vue生命周期?
答:vue实例从创建到销毁的过程就是生命周期。从开始创建、初始化数据、编译模板、挂载(DOM)→渲染更新→渲染销毁等一系列过程,称之为VUE的生命周期。

②vue的生命周期的作用是什么?
答:它的生命周期有多个事件钩子,让我们在控制整个VUE实例的过程时更容易形成好的逻辑。

③vue的生命周期总共有几个阶段?
答:它可以总共分为8个阶段:创建前/后 载入前/后  更新前/后,销毁前/后

④第一次页面加载会触发那几个钩子
答:会触发下面几个钩子 beforeCreate created beforeMount mounted

⑤DOM渲染在哪个周期中已经完成?
答:DOM渲染在mounted中已经完成

3、VUE实现数据双向绑定的原理 object.definePropty()
UVE实现数据双向绑定主要是:采用数据劫持接口发布者订阅模式的方式,通过object.defineProperty()来劫持各个属性的setter,getter,在数据变动时发布消息给订阅者,触发相应监听回调。档把一个普通的javascript对象传给vue实例来作为她的data选项时,vue将便利它的属性,用Obeject.defineProperty将他们转为getter/setter。用户看不到getter/setter,但是在内部它们让vue追踪依赖,在属性被访问和修改时通知变化。

vue的数据双向绑定将MVVM作为数据绑定的入口,整合observer,compile和watcher三者,通过observer来监听自己的model的数据变化,通过compile来解析编译模板指令(vue中是用来解析{{}}),最终利用watcher搭起observe和compile之间的通信桥梁,达到数据变化 →视图更新;视图交互变化(input)→数据model变更双向绑定效果。

4、VUE组件间的参数传值

①父组件和子组件传值
父组件传给子组件:子组件通过props方法接受数据;
子组件传给父组件:$emit方法传递参数
②非父子组件间的数据传递,兄弟组件传值
eventBus,就是创建一个事件中心,相当于中转站,可以用它来传递事件和接受事件。项目比较小时,用这个比较合适。(vuex也可以)

5、VUE的路由实现:hash模式和history模式
hash模式:在浏览器符号有“#”以及“#”后面的字符称之为hash,用window.location.hash读取;
特点:hash虽然在URL中,但不包括在HTTP请求中;用来指导浏览器动作,对于服务端安全无用,hash不会重载页面。
hash模式下,仅hash符号之间的内容会被包含在请求中,如http:xxxx.com,因此对于后端来说,及时没有做对到对路由的全覆盖,也不会返回404

history模式history模式采用h5习特性,使用俩新方法:pushState(),replaceState()可以对浏览器历史记录栈进行修改,以及popState事件的监听到状态变更。
history模式下,前端的url必须和实际想后端发起请求的url一致,如http://wwww.xxx.com/list/id。后端如果缺少了对/list/id的路由处理,将会返回404。vue-router官网描述:不过这种模式要玩好,所以还要后台配置支持。。。所以呢,你要在服务端增加一个覆盖所有情况的候选志愿:如果url匹配不到任何静态资源,则应该返回同一个index.html页面,这个页面就是你app依赖的页面。

6、vue与angular以及react的区别
api vue全面

7、vue的路由钩子函数
首页可以控制导航跳转,beforeEach afterEach等,一般用于页面title修改,一些需要登录才能调整页面的重定向登录
beforeEach 有 to from next 三个
to:route即将进入的目标路由对象
from:route当前导航正要离开的路由
next:function一定要调用该方法的resolve这个钩子,执行效果依赖next()方法的调用参数。可以控制页面的跳转。

8、VUEX是什么?怎么使用?哪种功能场景使用它?
只用来读取的状态集中放在store中;改变状态的方式是提交mutations,这个是同步的数据,异步逻辑应该封装在acticon里面。
在main.js引入store,注入,建一个目录store . export
场景:单页面应用中,组件之间的状态,登录状态等




state
vuex使用单一状态树,即每个应用将仅仅包含一个stroe实例,但单一状态树和模块化并不冲突。存放的数据状态,不可以直接修改里面的数据。
mutations
mutations定义的方法动态修改vuex的store的状态或数据。
getters
类似vue计算属性,主要通过过滤一些数据
action
actions可以理解为通过将mutations里面处理数据的方法变成可以异步处理数据的方法,简单说就是异步操作数据。view层通过store.dispath来分发action

const store=new Vuex.Store({
state:{
count:0
},
mutations:{
increment(state){
state.count++
}
},
actions:{
increment(context){
context.commit(‘increment’)}
}
})

modules
项目特别复杂的时候,可以让每一个模块拥有自己的state、mutation、action、getters使得结构非常清晰,方便管理

const moduleA = {
state: { … },
mutations: { … },
actions: { … },
getters: { … }
}
const moduleB = {
state: { … },
mutations: { … },
actions: { … }
}

const store = new Vuex.Store({
modules: {
a: moduleA,
b: moduleB
})

9、vue-cli如何新增自定义指令?
①创建局部指令
var app = new Vue({
el:’#app’,
data:{

},

// 创建指令(可以多个)
directives: {
// 指令名称
dir1: {
inserted(el) {
// 指令中第一个参数是当前使用指令的DOM
console.log(el);
console.log(arguments);
// 对DOM进行操作
el.style.width = ‘200px’;
el.style.height = ‘200px’;
el.style.background = ‘#000’;
}
}
}



})

②全局指令
Vue.directive(‘dir2’,{
inserted(el){

}
})

③指令的使用

<div id="app">
    <div v-dir1></div>
    <div v-dir2></div>
</div>
10、vue如何自定义一个过滤器
{{msg| capitalize }}
var vm=new Vue({
    el:"#app",
    data:{
        msg:''
    },
    filters: {
      capitalize: function (value) {
        if (!value) return ''
        value = value.toString()
        return value.charAt(0).toUpperCase() + value.slice(1)
      }
    }

全局定义过滤器
Vue.filter('capitalize', function (value) {
  if (!value) return ''
  value = value.toString()
  return value.charAt(0).toUpperCase() + value.slice(1)
})

过滤器接收表达式的值(msg)作为第一个参数。capitalize过滤器将会受到msg的值作为第一个参数

11、对keep-alive的了解?
keep-alive是vue内置的一个组件,可以使被包含的组件保留状态,或避免重新渲染。include(包含组件的缓存) exclude(排除组件的不缓存,优先级大于include)

使用方法:
<keep-alive include=”include_componens” exclude=”exclude_components”>
<component>
<!– 该组件是否缓存取决于include和exclude属性 –>
</component>
参数解释
include-字符串或正则表达式,只有名称匹配的组件会被缓存
exclude-字符串或正则表达式,任何名称匹配的组件都不会被缓存
include和exclude的属性允许组件有条件滴缓存。二斗都可以用”,“”分隔字符串、正则表达式、数组。当使用正则或者数组的时候,要用v-bind“
使用实例
<keep-alive include=”a,b”>
<component></component>
</keep-alive>

<!– 正则表达式(需要使用v-bind,符合匹配规则的都会被缓存) –>
<keep-alive :include=”/a|b/”>
<component></component>
</keep-alive>

<!– Array需要使用v-bind,被包含的都会被缓存 –>
<keep-alive :include=”[‘a’,’b’]”>
<component></component>
</keep-alive>
12、其他面试题
①css只在当前组件内起作用
在style标签中写入scoped即可 例如<style scoped></style>


②v-if和v-show的区别
v-if是按照条件渲染的,v-show是display的block和none。v-if 有更高的切换开销,而 v-show 有更高的初始渲染开销。因此,如果需要非常频繁地切换,则使用 v-show 较好;如果在运行时条件不太可能改变,则使用 v-if 较好

③$route和$router的区别
$route是”路由信息对象“,包括path,param,hash,query,fullpath,matched,name等路由信息参数。而$router是”路由实例“对象包括了路由的跳转方法,钩子函数等。

④vue.js的两个核心是数据驱动和组件系统

⑤vue的常用指令 v-for v-if v-show v-else v-bind v-on

⑥vue常用的修饰符 .prevent:提交页面不在重载页面;.stop:阻止单击事件冒泡;.self:当事件发生在该元素本身而不是子元素的时候回触发;.capture:事件侦听,事件发生的时候回调用

⑦v-on可以绑定多个方法
⑧vue中key值得作用
当vue.js用v-for正在更新已渲染过得元素列表时,它就默认的”就地复用“策略。如果数据的顺序被改变,vue将不会移动DOM元素来匹配数据项的顺序,而是简单复用此处的每个元素,并且确保它在特定的索引下显示已被渲染过得每个元素。key的作用主要是为了更高效的更新虚拟DOM
⑨什么是vue的计算属性
答:在模板中放入了太多的逻辑会让模板过重难以维护,在需要对数据进行复杂处理,且可能多次使用的情况下,尽量采取计算属性的方式。
好处:1)使得数据处理结构清晰
2)依赖于数据,数据更新,处理结果自动更新
3)计算属性内部this指向vm实例
4)在template调用时,直接写计算属性名即可
5)常用的getter方法,获取数据,也可以使用set方法改编数据
6)methods,不管依赖的数据变不变,methods都会重新技术,但是依赖的数据不变的时候computed从缓存中获取,不会重新计算
10、vue等页面应用及其优缺点
vue的目标是通过尽可能简单的api实现响应的数据绑定和组合的视图组件。核心是一个相应的数据绑定系统。MVVM、数据驱动、组件化、轻量化、简洁高效快速,模块友好。
缺点:不支持低版本浏览器(其实这也是优点,有助于推动浏览器厂商的标准化)不利于SEO的优化。如果要支持SEO,需要通过服务端来进行渲染组件。;第一次加载首页耗时相对长一些。不能使用导航按钮需要自行实现前进后退