vue实现数据双向绑定主要是:采用数据劫持结合发布者-订阅者模式
的方式,经过 Object.defineProperty()
来劫持各个属性的setter
,getter
,在数据变更时发布消息给订阅者,触发相应监听回调。当把一个普通Javascript
对象传给Vue
实例来做为它的data
选项时,Vue 将遍历它的属性,用Object.defineProperty()
将它们转为getter/setter
。用户看不到 getter/setter
,可是在内部它们让 Vue 追踪依赖,在属性被访问和修改时通知变化。javascript
vue的数据双向绑定 将MVVM做为数据绑定的入口,整合Observer
,Compile
和Watcher
三者,经过Observer
来监听本身的model
的数据变化,经过Compile
来解析编译模板指令(vue中是用来解析 {{}}
),最终利用watcher
搭起observer
和Compile
之间的通讯桥梁,达到数据变化 —>视图更新;视图交互变化(input)—>数据model变动
双向绑定效果。html
<div id="app"> <input type="text" id="txt"> <p id="show"></p> </div> <script type="text/javascript"> var obj = {} Object.defineProperty(obj,'txt',{ get:function () { return obj }, set:function (newVal) { document.getElementById('txt').value = newVal document.getElementById('show').innerHTML = newVal } }) document.addEventListener('keyup',function(e){ obj.txt = e.target.value }) </script>