大家好,又见面了,我是你们的朋友全栈君。
为什么会失效呢
首先
vue数据双向绑定是通过数据劫持结合发布者-订阅者模式的方式来实现的
实现方式是get和set方法
然后是通过Object.defineProperty()来实现数据劫持的。
然后呢要是,实现数据的双向绑定,首先要对数据进行劫持监听,因为写的代码没有被监听到,所以只能手动set
代码语言:javascript复制this.$set(obj,key,value)
查找的资料:
代码语言:javascript复制1.实现一个监听器Observer,用来劫持并监听所有属性,如果有变动的,就通知订阅者。
2.实现一个订阅者Watcher,可以收到属性的变化通知并执行相应的函数,从而更新视图。
3.实现一个解析器Compile,可以扫描和解析每个节点的相关指令,并根据初始化模板数据以及初始化相应的订阅器
大致流程,所以绑定失败的时候多数是卡到了监听。。。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。