Bootstrap

手把手,从无到有带你用vue进行项目实战 系列三(深入剖析vue篇)

相关链接:

手把手,从无到有带你用vue进行项目实战 系列一(搭建框架篇)

手把手,从无到有带你用vue进行项目实战 系列二(cdn、gzip性能加速篇)


对Vue的解析主要分为简介、核心内容、组件、路由和状态管理四部分

一、简介

Vue.js主要有四个特点

  • 简单小巧 : Vue.js压缩后只有17k
  • 渐进式 : 可以一步步有阶段的使用而不必一开始使用所有东西
  • 响应式 : 保持视图和状态同步
  • 组件化 : 与react类似,一切都是组件

知识点 : Vue.js如何实现数据双向绑定?

Vue.js的响应式使用起来很简单,不需要引入太多的新概念,声明实例new Vue({data:data})后对data里面的数据进行视图上的绑定。修改data数据,视图中相应数据也会随之修改。

详析

Vue 使用基于依赖追踪的观察系统并且异步队列更新,所有的数据变化都是独立触发,除非它们之间有明确的依赖关系。 vue.js 采用数据劫持结合发布者-订阅者模式的方式,通过Object.defineProperty()来劫持各个属性的setter,getter,在数据变动时发布消息给订阅者,触发相应的监听回调。

该方法允许精确添加或修改对象的属性。通过赋值来添加的普通属性会创建在属性枚举期间显示的属性(for...in 或 Object.keys 方法), 这些值可以被改变,也可以被删除。这种方法允许这些额外的细节从默认值改变。

知识点 : 数组更新检测注意事项

由于vue检测到数组更新后会触发视图更新,因此单独列出来

变异方法(mutating method 改变原数组)
    push(), pop(), shift(), unshift(), splice(), sort(), reverse() 
非变异 (non-mutating method) 
    filter(), concat() 和 slice() 

注意:
由于 JavaScript 的限制,Vue 不能检测以下变动的数组:
	1.	当你利用索引直接设置一个项时,例如:vm.items[indexOfItem] = newValue
	2.	当你修改数组的长度时,例如:vm.items.length = newLength
为了解决第一类问题,以下两种方式都可以实现和 vm.items[indexOfItem] = newValue 相同的效果,同时也将触发状态更新:
// Vue.set
Vue.set(example1.items, indexOfItem, newValue)
// Array.prototype.splice
example1.items.splice(indexOfItem, 1, newValue)
为了解决第二类问题,你可以使用 spliceexample1.items.splice(newLength)

知识点 : 对象更改注意事项

还是由于 JavaScript 的限制,Vue 不能检测对象属性的添加或删除:
var vm = new Vue({
  data: {
    a: 1
  }
})
// `vm.a` 现在是响应式的

vm.b = 2
// `vm.b` 不是响应式的
对于已经创建的实例,Vue 不能动态添加根级别的响应式属性。
但是,可以使用 Vue.set(object, key, value) 方法向嵌套对象添加响应式属性

总结:使用Vue.js可以让开发更简单,同时颠覆了传统前端开发模式,提供现代web开发中常见的功能:

  • 解耦视图与数据
  • 可复用的组件
  • 前端路由
  • 状态管理
  • 虚拟DOM

二、核心内容

Vue.js具有渐进式的特点,核心部分实现基础功能,路由、状态管理和对服务的封装使用插件,这一部分我们主要解析核心内容

1、生命周期

每个 Vue 实例在被创建之前都要经过一系列的初始化过程。例如需要设置数据监听、编译模板、挂载实例到 DOM、在数据变化时更新 DOM 等。同时在这个过程中也会运行一些叫做生命周期钩子的函数,给予用户可以在一些特定的场景下添加他们自己的代码。常用的钩子

;