- 一个循环解决行转树的问题
- 转树除了添加
children
属性,不会修改任何数据 - 支持任意关系字段,如:非 id,parentId, children 字段支持
- 支持接管插入行为,如:自定义插入顺序
- 支持动态导出树节点
- 内置
filter/map
函数
快速开始
国内镜像
文档
安装
$ npm i @zhengxs/js.tree --save
使用
import { toTree } from '@zhengxs/js.tree'
toTree([
{ id: 10000, parentId: null, title: '标题 1' },
{ id: 20000, parentId: null, title: '标题 2' },
{ id: 11000, parentId: 10000, title: '标题 1-1' },
])
支持任意关系字段的数据
import { toTree, ROOT_ID } from '@zhengxs/js.tree'
const data = [
{ uid: 10000, pid: null, title: '标题 1', sort: 1 },
{ uid: 20000, pid: null, title: '标题 2', sort: 2 },
{ uid: 11000, pid: 10000, title: '标题 1-1', sort: 3 },
]
const result = toTree(data, {
root: ROOT_ID,
idKey: 'uid',
parentKey: 'pid',
childrenKey: 'items',
transform(data) {
return { ...data, checked: false }
},
insert(siblings, node) {
const index = siblings.findIndex((n) => n.sort > node.sort)
if (index === -1) {
siblings.push(node)
} else {
siblings.splice(index, 0, node)
}
},
})
Try in runkit
TypeScript
内置 ts 类型
import { toTree } from '@zhengxs/js.tree'
type MenuItem = {
id: string
parentId: string
text: string
url?: string
}
interface Nav extends MenuItem {
items: Nav[]
}
toTree<Nav>(source, {
childrenKey: 'items',
})
对不同构建版本的解释
umd 模块使用 es5
,其他版本使用的是 es2015
。
在包的 dist/ 目录你将会找到很多不同的构建版本,这里列出了它们之间的差别:
| UMD | CommonJS | ES Module |
---|
无依赖 | js.tree.js | js.tree.common.js | js.tree.esm.js |
无依赖(生产环境) | js.tree.min.js | | |
包含 lodash 模块 | | js.tree.common.lodash.js | js.tree.esm.lodash.js |
包含 lodash-es 模块 | | | js.tree.esm.lodash-es.js |
除环境导致的,为了减少包体积,和项目共享 lodash
模块。
但不是所有项目都会引入,为了避免这种情况,默认的都是不带的。
License