前端的数据双向绑定指的是view(视图)和model(数据)二者之间的关系;view层是页面上展现给用户看的信息,model层通常是指经过http请求从后台返回的数据。view到model的绑定都是经过事件回调函数操做的,model到view的绑定有多种方法。前端
angular,react,vue等mv*模式的框架都实现了数据双向绑定;angular是经过脏检查即新老数据的比较来肯定哪些数据发生了变化,从而将它更新到view中;vue则是经过设置数据的get和set函数来实现的,这种方式在性能上是优于angular的。vue
下面代码是一个简单的定义数据get和set方法的例子,set和get方法分别在数据改变和访问的时候被调用,可以监听数据的变化:react
1 // 数据绑定的构造函数
2 function Observer(data) {
3 this.data = data; 4 5 for(var key in data) { 6 if(data.hasOwnProperty(key)) { 7 var val = data[key]; 8 if(typeof data[key] === "object"){ 9 // 若是值不为原始类型,则继续递归 10 new Observer(val); 11 }else { 12 this.convert(key, val); 13 } 14 } 15 } 16 } 17 // 定义set 和 get函数 18 Observer.prototype.convert = function(key, val) { 19 Object.defineProperty(this.data, key, { 20 enumerable: true, 21 confingurable: true, 22 get: function() { 23 console.log(key + "被访问了"); 24 return val; 25 }, 26 set: function(newVal) { 27 console.log(key + "被设置了新值" + newVal); 28 val = newVal; 29 } 30 }); 31 } 32 var app = new Observer({name: "xieshuai", age: 24, address: {city: "shenzheng"}}); 33 34 app.data.name; // name被访问了 35 app.data.age = 18; // age被设置了新值18
Object.defineProperty,这是ES5新增的方法,经过这个方法,能够自定义getter和setter函数。数组
上面的代码只是个简单的例子,并无处理数组的状况;不过这是vue实现数据双向绑定的核心。app
本文到此结束,文中如有不对之处,还望指正。框架