![9715bee0ed62958b225909e298ea6f25.png](https://i-blog.csdnimg.cn/blog_migrate/57842bbf92b7bfe283ea64fdbaa7e7d7.jpeg)
当你把一个普通的 JavaScript 对象传给 Vue 实例的data选项,Vue 将遍历此对象所有的属性,并使用Object.defineProperty把这些属性全部转为getter/setter。
这些 getter/setter 对用户来说是不可见的,但是在内部它们让 Vue 追踪依赖,在属性被访问和修改时通知变化。这里需要注意的问题是浏览器控制台在打印数据对象时 getter/setter 的格式化并不同,所以你可能需要安装vue-devtools来获取更加友好的检查接口。
每个组件实例都有相应的 watcher实例对象,它会在组件渲染的过程中把属性记录为依赖,之后当依赖项的setter被调用时,会通知watcher重新计算,从而致使它关联的组件得以更新。
![2d28ac6877213bfc6aa3867eb5387f6b.png](https://i-blog.csdnimg.cn/blog_migrate/f2367fd5429797323d0df8630e405457.jpeg)
关于虚拟DOM:在底层的实现上,Vue 将模板编译成虚拟 DOM 渲染函数。结合响应系统,Vue 能够智能地计算出最少需要重新渲染多少组件,并把 D