Vue实现双向数据绑定
Vue实现双向数据绑定的方式,具体内容如下 Vue是如何实现双向数据绑定的呢?答案是前端数据劫持。其通过Object.defineProperty()方法,这个方法可以设置getter和setter函数,在setter函数中,就可以监听到数据的变化,从而更新绑定的元素的值。 实现对象属性变化绑定到UI 大概的思路是: 1. 确定绑定的数据,使用Object.defineProperty()对其数据变化进行监听(对应defineGetAndSet) 2. 一旦数据发生改动,会触发setter函数。因此在setter函数内要调用回调函数触发绑定元素的更新。 3. 绑定元素的更新就是遍历所有的绑定元素,通过绑定属性的值确定函数的调用,并传入修改后的值。(对应scan) 实现UI变化绑定到对象属性 这个就比较简单了,因为UI的改变会触发一些事件,比如keyup。通过监听事件来实现数据的改变。而上面说了,数据的改变又会导致绑定其值的元素的UI改变。 实现=0) {
command[attr.nodeName.slice(2)].call(elem,data[attr.nodeValue]);
}
}
}
}
//设置劫持
var defineGetAndSet = function(obj,propname) {
Object.defineProperty(obj,propname,{
get: function() {
return bindValue;
},set: function(value){
bindValue = value;
scan();
},enumerable: true,configurable: true
})
}
//一开始先初始化,使所有绑定的元素值为初始值
scan();
//设置需要被劫持的元素
defineGetAndSet(data,'value');
//监听UI变化
bindelems[1].addEventListener('keyup',function(e) {
data.value = e.target.value;
});
setTimeout(function() {
data.value = 'change';
},1000);
参考: 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |