欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Vue实现双向数据绑定

程序员文章站 2022-08-28 20:34:41
vue实现双向数据绑定的方式,具体内容如下 vue是如何实现双向数据绑定的呢?答案是前端数据劫持。其通过object.defineproperty()方法,这个方法可以设...

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

参考:

剖析vue原理&实现双向绑定mvvm

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