• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

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

vue 搞代码 4年前 (2022-01-08) 12次浏览 已收录 0个评论

这篇文章主要为大家详细解析了vue.js数据双向绑定原理,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

前端的数据双向绑定指的是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"){ // 如<em>本文来源[email protected]搞@^&代*@码2网</em>果值不为原始类型,则继续递归 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)的详细内容,更多请关注gaodaima搞代码网其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:vue数据双向绑定原理解析(get & set)

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址