Vue:实现双向数据绑定
参考剖析Vue原理&实现双向绑定MVVMjavascript实现数据双向绑定的三种方式Vue实现双向数据绑定的方式Vue是如何实现双向数据绑定的呢?答案是前端数据劫持。其通过Object.defineProperty()方法,这个方法可以设置getter和setter函数,在setter函数中,就可以监听到数据的变化,从而更新绑定的元素的值。实现对象属性变化绑定到UI大概的思路是:1. 确定
·
参考
剖析Vue原理&实现双向绑定MVVM
javascript实现数据双向绑定的三种方式
Vue实现双向数据绑定的方式
Vue是如何实现双向数据绑定的呢?答案是前端数据劫持。其通过Object.defineProperty()
方法,这个方法可以设置getter
和setter
函数,在setter函数中,就可以监听到数据的变化,从而更新绑定的元素的值。
实现对象属性变化绑定到UI
大概的思路是:
1. 确定绑定的数据,使用Object.defineProperty()对其数据变化进行监听(对应defineGetAndSet)
2. 一旦数据发生改动,会触发setter函数。因此在setter函数内要调用回调函数触发绑定元素的更新。
3. 绑定元素的更新就是遍历所有的绑定元素,通过绑定属性的值确定函数的调用,并传入修改后的值。(对应scan)
实现UI变化绑定到对象属性
这个就比较简单了,因为UI的改变会触发一些事件,比如keyup。通过监听事件来实现数据的改变。而上面说了,数据的改变又会导致绑定其值的元素的UI改变。
实现
var data = {
value: 'hello world!'
}
var bindValue;
//确定绑定的元素
var bindelems = [document.getElementById('p'), document.getElementById('input')];
//修改绑定元素的值的方法
var command = {
text: function(str) {
this.innerHTML = str;
},
value: function(str) {
this.value = str;
}
};
//遍历绑定元素修改其值
var scan = function() {
console.log('in scan');
for(var i = 0; i < bindelems.length; i++) {
var elem = bindelems[i];
console.log('elem',elem);
for(var j = 0; j < elem.attributes.length; j++) {
var attr = elem.attributes[j];
if(attr.nodeName.indexOf('q-')>=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);
更多推荐
已为社区贡献2条内容
所有评论(0)