vue复选框实现双向数据绑定 Vue是如何实现双向数据绑定的?
Vue是如何实现双向数据绑定的?
数据与视图的绑定与同步,最终体现在对数据的读写处理过程中,也就是 Object.defineProperty() 定义的数据 set、get 函数中。Vue 中对于的函数为 defineReactive,在精简版实现中,我只保留了一些基本特性:
function defineReactive(obj, key, value) {
var dep = new Dep()
Object.defineProperty(obj, key, {
enumerable: true,
configurable: true,
get: function reactiveGetter() {
if (Dep.target) {
dep.depend()
}
return value
},
set: function reactiveSetter(newVal) {
if (value === newVal) {
return
} else {
value = newVal
dep.notify()
}
}
})
}
在对数据进行读取时,如果当前有 Watcher(对数据的观察者吧,watcher 会负责将获取的新数据发送给视图),那将该 Watcher 绑定到当前的数据上(dep.depend(),dep 关联当前数据和所有的 watcher 的依赖关系),是一个检查并记录依赖的过程。而在对数据进行赋值时,如果数据发生改变,则通知所有的 watcher(借助 dep.notify())。这样,即便是我们手动改变了数据,框架也能够自动将数据同步到视图。
VUE数据响应原理真的是双向绑定吗?效果如何?
vue2.x是以object.defineProperty来实现的
问题是不能检测到数组对象内部的数据变化 vue3.x是用的是es6的proxy来实现的 可以检测到数组内部的变化 具体可以看看我写的文章
vue2.x和vue3.x双向数据绑定的区别一文
vue复选框实现双向数据绑定 vue自定义组件实现双向数据绑定 vue是如何实现双向绑定的
版权声明:本文内容由互联网用户自发贡献,本站不承担相关法律责任.如有侵权/违法内容,本站将立刻删除。