美娱国际平台:Vue实现双向数据绑定

标签:公司介绍    日期:2019-05-23 17:35    录入:美娱国际平台注册    浏览:

  

[Vue,数据绑定]Vue实现双向数据绑定

  

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);  
  
  

参考:  

  

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

  

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

  

以上就是本文的全部内容,希美娱国际平台望对大家的学习有所帮助,也希望大家多多支持。

  
  

★★★小编:美娱国际 整理文章,欢迎大家转载 ★★★
上一篇:JavaScript中this详解
下一篇:没有了
相关文章阅读