重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
Vue实现双向数据绑定的方式,具体内容如下
创新互联专注于企业全网整合营销推广、网站重做改版、尼河口网站定制设计、自适应品牌网站建设、H5响应式网站、商城网站定制开发、集团公司官网建设、成都外贸网站建设公司、高端网站制作、响应式网页设计等建站业务,价格优惠性价比高,为尼河口等各大城市提供网站开发制作服务。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);
另外有需要云服务器可以了解下创新互联建站www.cdcxhl.com,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。