文件路径 : ./src/hooks.ts
这个文件主要是定义了 Virtual Dom 在实现过程中,在其执行过程中的一系列钩子。方便外部做一些处理
// 钩子
export interface Hooks {
// 在 `patch` 开始执行的时候调用
pre?: PreHook;
// 在 `createElm`,进入的时候调用init
// vnode转换为真实DOM节点时触发
init?: InitHook;
// 创建真实DOM的时候,调用 create
create?: CreateHook;
// 在`patch`方法接近完成的时候,才收集所有的插入节点,遍历调用响应的钩子
// 可以认为插入到DOM树时触发
insert?: InsertHook;
// 在两个节点开始对比前调用
prepatch?: PrePatchHook;
// 更新过程中,调用update
update?: UpdateHook;
// 两个节点对比完成时候调用
postpatch?: PostPatchHook;
// 删除节点的时候调用,包括子节点的destroy也会被触发
destroy?: DestroyHook;
// 删除当前节点的时候调用。元素从父节点删除时触发,和destory略有不同,remove只影响到被移除节点中最顶层的节点
remove?: RemoveHook;
// 在`patch`方法的最后调用,也就是patch完成后触发
post?: PostHook;
}
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。