为什么会失效呢
首先
vue数据双向绑定是通过数据劫持结合发布者-订阅者模式的方式来实现的
实现方式是get和set方法
然后是通过Object.defineProperty()来实现数据劫持的。
然后呢要是,实现数据的双向绑定,首先要对数据进行劫持监听,因为写的代码没有被监听到,所以只能手动set
this.$set(obj,key,value)
查找的资料:
1.实现一个监听器Observer,用来劫持并监听所有属性,如果有变动的,就通知订阅者。
2.实现一个订阅者Watcher,可以收到属性的变化通知并执行相应的函数,从而更新视图。
3.实现一个解析器Compile,可以扫描和解析每个节点的相关指令,并根据初始化模板数据以及初始化相应的订阅器
大致流程,所以绑定失败的时候多数是卡到了监听。。。
因篇幅问题不能全部显示,请点此查看更多更全内容