1、响应式数据
如果内存中的数据变化了 页面UI也会动态跟着刷新 这种数据就是响应式数据
响应式数据设计原理:
vue2.0采用数据劫持结合发布者-订阅者模式的方式,通过Object.defineProperty()来劫持各个属性的setter,getter,在数据变动时发布消息给订阅者,触发相应监听回调。当把一个普通 Javascript对象传给Vue实例来作为它的data选项时,Vue将遍历它的属性,用Object.defineProperty将它们转为getter/setter。用户看不到getter/setter,但是在内部它们让Vue 追踪依赖,在属性被访问和修改时通知变化。
Vue3.0使用es6 proxy代理了data对象
2、双向数据绑定
什么是双向数据绑定:(1)如果数据容器中的数据变了也会让页面刷新(DOM操作让页面改变)
(2)用户操作了页面也会让数据容器中的数据的值发生改变
实现双向数据绑定由v-model实现,v-model实际上是一个语法糖,他负责监听用户的输入事件以更新数据