博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
vuejs数据双向绑定原理(get & set)
阅读量:5333 次
发布时间:2019-06-15

本文共 1305 字,大约阅读时间需要 4 分钟。

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

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

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

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

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

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

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

转载于:https://www.cnblogs.com/xshuai/p/6516680.html

你可能感兴趣的文章
【转载】Visual Studio + VA 常用快捷键
查看>>
Android SDK Manager国内无法更新的解决方案
查看>>
20145303刘俊谦 Exp8 Web基础
查看>>
吴裕雄 Bootstrap 前端框架开发——Bootstrap 图片:响应式图片
查看>>
吴裕雄--天生自然 JAVA开发学习:Number & Math 类
查看>>
cf 558c Amr and Chemistry
查看>>
结对review
查看>>
java基本类型(内置类型)取值范围
查看>>
CAD&CG GDC 2018大会论文录用名单
查看>>
Mac 中文输入法失效(不显示选词框)解决办法
查看>>
基于 Laravel 开发博客应用系列 —— 设置 Linux/Mac 本地开发环境
查看>>
C语言基础-第五章
查看>>
CSS的一些命名
查看>>
[LeetCode]Valid Sudoku
查看>>
[leetcode]110BalancedBinaryTree平衡二叉树
查看>>
SQL中INNER JOIN、LEFT JOIN、RIGHT JOIN、FULL JOIN区别
查看>>
学计算机的你伤不起啊
查看>>
Django+MongoDB批量插入数据
查看>>
GPS坐标换算为百度坐标
查看>>
Linux命令整理-Ubuntu
查看>>