- 第一步:解析模板成
render
函数 - 第二步:响应式开始监听
- 第三步:首次渲染,显示页面,且绑定依赖
- 第四步:
data
属性变化,触发rerender
第一步:解析模板成 render
函数
- 模板中的所有信息都被
render
函数包含 - 模板中用到的
data
中的属性,都变成了JS
变量 - 模板中的
v-model v-for v-on
都变成了JS
逻辑 render
函数返回vnode
第二步:响应式开始监听
Object.defineProperty
- 将
data
的属性代理到vm
上
第三步:首次渲染,显示页面,且绑定依赖
- 初次渲染,执行
updateComponent
,执行vm._render()
- 执行
render
函数,会访问到vm.list vm.title
- 会被响应式的
get
方法监听到 - 执行
updateComponent
,会走到vdom
的patch
方法 patch
将vnode
渲染成DOM
,初次渲染完成
为何要监听 get ,直接监听 set 不行吗?
data
中有很多属性,有些被用到,有些可能不被用到- 被用到的会走到
get
,不被用到的不会走到get
- 未走到
get
中的属性,set
的时候我们也无需关心 - 避免不必要的重复渲染
第四步:data
属性变化
- 修改属性,被响应式的
set
监听到 set
中执行updateComponent
updateComponent
重新执行vm._render()
- 生成的
vnode
和prevVnode
,通过patch
进行对比 - 渲染到
html
中