Vue实现双向数据绑定

网友投稿 228 2023-05-19


Vue实现双向数据绑定

vue实现双向数据绑定的方式,具体内容如下

Vue是如何实现双向数据绑定的呢?答案是前端数据劫持。其通过Object.defineProperty()OYDCgD方法,这个方法可以设置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', functiohttp://n(e) {

data.value = e.target.value;

});

setTimeout(function() {

data.value = 'change';

}, 1000);

参考:

javascript实现数据双向绑定的三种方式

剖析Vue原理&实现双向绑定MVVM


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:javaWeb项目部署到阿里云服务器步骤详解
下一篇:详解Java中LinkedHashMap
相关文章

 发表评论

暂时没有评论,来抢沙发吧~