visitor 函数。visitor 函数可以返回 false 来提前终止整个遍历。forEachforEach 方法以深度优先的顺序遍历树中的每一个节点,并对每个节点执行 visitor 函数。
import { Tree } from '@movk/core'
const tree = [{ id: 1, name: 'A', children: [{ id: 2, name: 'B' }] }]
const names: string[] = []
Tree.forEach(tree, ({ node }) => {
names.push(node.name)
})
// names => ['A', 'B']
// 提前终止
Tree.forEach(tree, ({ node }) => {
if (node.name === 'A') {
return false // 停止遍历
}
})
forEach<T extends TreeNode>(tree: T[], visitor: (context: VisitorContext<T>) => void | false, config?: TreeConfig): void
true,该节点及其所有父节点将被保留在结果中。
该函数接收一个包含以下属性的 context 对象:id, pid, children 键名的配置对象。