vue数据双向绑定原理解析(get & set)
2019/6/27 21:06:48
本文主要是介绍vue数据双向绑定原理解析(get & set),对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
前端的数据双向绑定指的是view(视图)和model(数据)两者之间的关系;view层是页面上展示给用户看的信息,model层一般是指通过http请求从后台返回的数据。view到model的绑定都是通过事件回调函数操作的,model到view的绑定有多种方法。
angular,react,vue等mv*模式的框架都实现了数据双向绑定;angular是通过脏检查即新老数据的比较来确定哪些数据发生了变化,从而将它更新到view中;vue则是通过设置数据的get和set函数来实现的,这种方式在性能上是优于angular的。
下面代码是一个简单的定义数据get和set方法的例子,set和get方法分别在数据改变和访问的时候被调用,能够监听数据的变化:
// 数据绑定的构造函数 function Observer(data) { this.data = data; for(var key in data) { if(data.hasOwnProperty(key)) { var val = data[key]; if(typeof data[key] === "object"){ // 如果值不为原始类型,则继续递归 new Observer(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 + "被访问了"); return val; }, set: function(newVal) { console.log(key + "被设置了新值" + newVal); val = newVal; } }); } var app = new Observer({name: "xieshuai", age: 24, address: {city: "shenzheng"}}); app.data.name; // name被访问了 app.data.age = 18; // age被设置了新值18
Object.defineProperty,这是ES6新增的方法,通过这个方法,可以自定义getter和setter函数。
上面的代码只是个简单的例子,并没有处理数组的情况;不过这是vue实现数据双向绑定的核心。
本文到此结束,文中若有不对之处,还望指正。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持找一找教程网。
这篇关于vue数据双向绑定原理解析(get & set)的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-24Vue CLI多环境配置学习:从入门到实践
- 2024-11-24Vue CLI多环境配置学习:新手入门教程
- 2024-11-24Vue CLI学习:初学者指南
- 2024-11-24Vue CLI学习:从入门到上手的简单教程
- 2024-11-24Vue3+Vite学习:从零开始的前端开发之旅
- 2024-11-24Vue3阿里系UI组件学习入门教程
- 2024-11-24Vue3的阿里系UI组件学习入门指南
- 2024-11-24Vue3公共组件学习:新手入门教程
- 2024-11-24Vue3公共组件学习入门指南
- 2024-11-24vue3核心功能响应式变量学习