持有一个 dep 实例,通过 dirty 属性标记计算属性是否需要重新求值当 computed 依赖值改变后,就会通知订阅的 watcher 进行更新,对于 computed watcher 会将 dirty...属性设置为 true,并且进行计算属性方法的调用,注意计算属性是基于他的响应式依赖进行缓存的,只有依赖发生改变的时候才会重新求值意义:比如计算属性方法内部操作非常频繁时,遍历一个极大的数组,计算一次可能要耗时...插件只能被安装一次,保证插件列表中不能有重复的插件需要将 Vue 作为 install 方法第一个参数传入,先将 Vue 保存起来,将传进来的 Vue 创建两个组件 router-link 和 router-view...模板编译又分为三个阶段,解析parse, 优化optimize, 生成generate,最终生成可执行函数render解析阶段 : 使用大量的正则表达式对 template 字符串进行解析,将标签,指令...,属性等转化为抽象语法树 AST优化阶段: 遍历 AST,找打其中的一些静态节点进行标记, 方便在页面重渲染的时候进行 diff 比较时,直接跳过这些静态节点,优化 runtime 的性能生成阶段: 将最终的