Version: 3.x
Reconciler
Taro 的运行时包括 DOM、BOM、React 兼容层、Vue 兼容层等内容,而不同的端平台或开发框架都有可能需要对 Taro 运行时进行侵入定制。
为了解耦,我们参考了 React Reconciler 的概念,外部可以通过提供一个自定义的 hostConfig
配置对象,对运行时进行定制。
遇到 hostConfig 的配置项不满足需求,需要进行扩展时,可以给 Taro 提交 PR~
#
hostConfig 配置#
appendChild (parent, child)DOMNode
调用 appendChild
方法时触发。
参数 | 类型 | 说明 |
---|---|---|
parent | DOMNode | 父节点 |
child | DOMNode / TextElement | 要给父节点追加的节点 |
#
removeChild (parent, child, oldChild)DOMNode
调用 replaceChild
方法时触发。
参数 | 类型 | 说明 |
---|---|---|
parent | DOMNode | 父节点 |
child | DOMNode / TextElement | 用来替换 oldChild 的新节点 |
oldChild | DOMNode / TextElement | 被替换掉的原始节点 |
#
insertBefore (parent, child, refChild)DOMNode
调用 insertBefore
方法时触发。
参数 | 类型 | 说明 |
---|---|---|
parent | DOMNode | 父节点 |
child | DOMNode / TextElement | 用于插入的节点 |
refChild | DOMNode / TextElement | 将要插在这个节点之前 |
#
removeAttribute (element, qualifiedName)DOMElement
调用 removeAttribute
方法时触发。
参数 | 类型 | 说明 |
---|---|---|
element | DOMElement | 当前操作元素 |
qualifiedName | string | 指定要从元素中移除的属性的名称 |
#
setAttribute (element, qualifiedName, value)DOMElement
调用 setAttribute
方法时触发。
参数 | 类型 | 说明 |
---|---|---|
element | DOMElement | 当前操作元素 |
qualifiedName | string | 表示属性名称的字符串 |
value | 属性的值/新值 |
#
prepareUpdateData (data, page)每次 Taro DOM 树更新,调用小程序 setData
前触发。
参数 | 类型 | 说明 |
---|---|---|
data | DataTree | 将要 setData 的 Taro DOM 树数据结构 |
page | TaroRootElement | 页面根元素 |
#
appendInitialPage (data, page)Taro DOM 树初始化,第一次调用小程序 setData
前触发。在调用 prepareUpdateData
后立刻执行。
参数 | 类型 | 说明 |
---|---|---|
data | DataTree | 将要 setData 的 Taro DOM 树数据结构 |
page | TaroRootElement | 页面根元素 |
#
getLifecyle (instance, lifecyle)小程序页面的生命周期被触发时调用。
参数 | 类型 | 说明 |
---|---|---|
instance | Instance | 用户编写的页面实例 |
lifecyle | string | 小程序页面被触发的生命周期函数名称 |
需要返回 function 或 function[],表示将要执行的函数。
例子:
#
onTaroElementCreate (tagName, nodeType)DOMElement
构造时触发。
参数 | 类型 | 说明 |
---|---|---|
tagName | string | 当前创建的元素的标签名 |
nodeType | NodeType | 当前创建的元素的节点类型 |
nodeType | 说明 | |
---|---|---|
1 | ELEMENT_NODE | |
2 | ATTRIBUTE_NODE | |
3 | TEXT_NODE | |
4 | CDATA_SECTION_NODE | |
5 | ENTITY_REFERENCE_NODE | |
6 | COMMENT_NODE | |
7 | PROCESSING_INSTRUCTION_NODE | |
9 | DOCUMENT_NODE |
#
getPathIndex (indexOfNode)DOMNode
获取 path
属性时触发。
参数 | 类型 | 说明 |
---|---|---|
indexOfNode | number | 当前节点在父节点 children 列表中的下标 |
需要返回一个 string 值,代表小程序按路径 setData
时的数组下标。
例子:
#
getEventCenter(Events)Taro.eventCenter
初始化值时触发。
参数 | 类型 | 说明 |
---|---|---|
Events | Taro 事件中心的构造函数 |
需要返回 Taro 事件中心的实例,其将会被赋值给 Taro.eventCenter
。
例子:
#
initNativeApi (taro)引用 @tarojs/taro
包时触发。
参数 | 类型 | 说明 |
---|---|---|
taro | Taro 对象 |
例子: