vue数据响应式的理解
响应式原理
数据响应式是指,在改变数据的时候,视图也会跟着更新。
当数据改变后,Vue会通知到使用该数据的代码。视图渲染中使用了数据,数据改变后,视图也会自动更新。
Vue的响应式原理依赖于 Object.defineProperty
, 通过设置对象的 getter/setter 方法来监听数据。
当你把一个普通的 JavaScript 对象传入 Vue 实例作为 data 选项,Vue 将遍历此对象所有的 property,并使用 Object.defineProperty 把这些 property 全部转为 getter/setter.
这些 getter/setter 对用户来说是不可见的,但是在内部它们让 Vue 能够追踪依赖,在 property 被访问和修改时通知变更。
由于 JavaScript 的限制,Vue 不能检测数组和对象的变化。
对于对象
Vue 无法检测 property 的添加或移除。由于 Vue 会在初始化实例时对 property 执行 getter/setter 转化,所以 property 必须在 data
对象上存在才能让 Vue 将它转换为响应式的。例如:
1 | var vm = new Vue({ |
对于已经创建的实例,Vue 不允许动态添加根级别的响应式 property。但是,可以使用 Vue.set(object, propertyName, value)
方法向嵌套对象添加响应式 property。例如,对于:
1 | Vue.set(vm.someObject, 'b', 2) |
您还可以使用 vm.$set
实例方法,这也是全局 Vue.set
方法的别名:
1 | this.$set(this.someObject,'b',2) |
有时你可能需要为已有对象赋值多个新 property,比如使用 Object.assign()
或 _.extend()
。但是,这样添加到对象上的新 property 不会触发更新。在这种情况下,你应该用原对象与要混合进去的对象的 property 一起创建一个新的对象。
1 | // 代替 `Object.assign(this.someObject, { a: 1, b: 2 })` |
对于数组
通过 vue 数组的变更方法来更新视图。