Vue实现双向数据绑定
Vue实现双向数据绑定的方式,具体内容如下
Vue是如何实现双向数据绑定的呢?答案是前端数据劫持。其通过Object.defineProperty()方法,这个方法可以设置getter和setter函数,在setter函数中,就可以监听到数据的变化,从而更新绑定的元素的值。
实现对象属性变化绑定到UI
大概的思路是:
1.确定绑定的数据,使用Object.defineProperty()对其数据变化进行监听(对应defineGetAndSet)
2.一旦数据发生改动,会触发setter函数。因此在setter函数内要调用回调函数触发绑定元素的更新。
3.绑定元素的更新就是遍历所有的绑定元素,通过绑定属性的值确定函数的调用,并传入修改后的值。(对应scan)
实现UI变化绑定到对象属性
这个就比较简单了,因为UI的改变会触发一些事件,比如keyup。通过监听事件来实现数据的改变。而上面说了,数据的改变又会导致绑定其值的元素的UI改变。
实现
vardata={ value:'helloworld!' } varbindValue; //确定绑定的元素 varbindelems=[document.getElementById('p'),document.getElementById('input')]; //修改绑定元素的值的方法 varcommand={ text:function(str){ this.innerHTML=str; }, value:function(str){ this.value=str; } }; //遍历绑定元素修改其值 varscan=function(){ console.log('inscan'); for(vari=0;i=0){ command[attr.nodeName.slice(2)].call(elem,data[attr.nodeValue]); } } } } //设置劫持 vardefineGetAndSet=function(obj,propname){ Object.defineProperty(obj,propname,{ get:function(){ returnbindValue; }, 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);
参考:
javascript实现数据双向绑定的三种方式
剖析Vue原理&实现双向绑定MVVM
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。