阿里云服务器怎么做网站,游戏源码平台,wordpress 过时,网网站基础建设优化知识Vue的双向数据绑定原理是什么#xff1f; 答#xff1a;vue.js 是采用数据劫持结合发布者-订阅者模式的方式#xff0c;通过Object.defineProperty()来劫持各个属性的setter#xff0c;getter#xff0c;在数据变动时发布消息给订阅者#xff0c;触发相应的监听回调。 具… Vue的双向数据绑定原理是什么 答vue.js 是采用数据劫持结合发布者-订阅者模式的方式通过Object.defineProperty()来劫持各个属性的settergetter在数据变动时发布消息给订阅者触发相应的监听回调。 具体步骤 第一步需要observe的数据对象进行递归遍历包括子属性对象的属性都加上 setter和getter这样的话给这个对象的某个值赋值就会触发setter那么就能监听到了数据变化 第二步compile解析模板指令将模板中的变量替换成数据然后初始化渲染页面视图并将每个指令对应的节点绑定更新函数添加监听数据的订阅者一旦数据有变动收到通知更新视图 第三步Watcher订阅者是Observer和Compile之间通信的桥梁主要做的事情是:1、在自身实例化时往属性订阅器(dep)里面添加自己2、自身必须有一个update()方法3、待属性变动dep.notice()通知时能调用自身的update()方法并触发Compile中绑定的回调则功成身退。 第四步MVVM作为数据绑定的入口整合Observer、Compile和Watcher三者通过Observer来监听自己的model数据变化通过Compile来解析编译模板指令最终利用Watcher搭起Observer和Compile之间的通信桥梁达到数据变化 - 视图更新视图交互变化(input) - 数据model变更的双向绑定效果。 转载于:https://www.cnblogs.com/manban/p/11158304.html