一聚教程网:一个值得你收藏的教程网站

最新下载

热门教程

vue数据双向绑定原理解析(get & set)

时间:2017-06-06 编辑:简简单单 来源:一聚教程网

前端的数据双向绑定指的是view(视图)和model(数据)两者之间的关系;view层是页面上展示给用户看的信息,model层一般是指通过http请求从后台返回的数据。view到model的绑定都是通过事件回调函数操作的,model到view的绑定有多种方法。

angular,react,vue等mv*模式的框架都实现了数据双向绑定;angular是通过脏检查即新老数据的比较来确定哪些数据发生了变化,从而将它更新到view中;vue则是通过设置数据的get和set函数来实现的,这种方式在性能上是优于angular的。

下面代码是一个简单的定义数据get和set方法的例子,set和get方法分别在数据改变和访问的时候被调用,能够监听数据的变化:

 

 代码如下复制代码

// 数据绑定的构造函数

functionObserver(data) {

 this.data = data;

 

 for(varkeyindata) {

  if(data.hasOwnProperty(key)) {

   varval = data[key];

   if(typeofdata[key] ==="object"){

    // 如果值不为原始类型,则继续递归

    newObserver(val);

   }else{

    this.convert(key, val);

   }

  }

 }

}

// 定义set 和 get函数

Observer.prototype.convert =function(key, val) {

 Object.defineProperty(this.data, key, {

  enumerable:true,

  confingurable:true,

  get:function() {

   console.log(key +"被访问了");

   returnval;

  },

  set:function(newVal) {

   console.log(key +"被设置了新值"+ newVal);

   val = newVal;

  }

 });

}

varapp =newObserver({name:"xieshuai", age: 24, address: {city:"shenzheng"}});

 

app.data.name; // name被访问了

app.data.age = 18;// age被设置了新值18

 

Object.defineProperty,这是ES6新增的方法,通过这个方法,可以自定义getter和setter函数。

上面的代码只是个简单的例子,并没有处理数组的情况;不过这是vue实现数据双向绑定的核心。

本文到此结束,文中若有不对之处,还望指正。

热门栏目