react TreeSelect异步加载树
时间: 2023-07-07 12:04:25 浏览: 174
React TreeSelect 组件支持通过异步请求加载树型结构数据。一般来说,异步加载树的数据可以通过以下步骤实现:
1. 首先,在 TreeSelect 组件中添加一个 `loadData` 属性,将其设置为一个异步函数,用于加载树的子节点数据。
2. 在 `loadData` 函数中,根据当前节点的 key 或其他标识符向后端发送异步请求,获取该节点的子节点数据。
3. 将获取到的子节点数据格式化为 TreeSelect 能够识别的数据格式,通常是一个包含 `value`,`label`,`children` 等属性的对象数组。
4. 将格式化后的子节点数据作为 `loadData` 函数的返回值,TreeSelect 组件会自动将其渲染为子节点。
下面是一个简单的示例代码:
```jsx
import { TreeSelect } from 'antd';
import { useEffect, useState } from 'react';
const loadData = async (treeNode) => {
const { value } = treeNode.props;
const response = await fetch(`/api/children?key=${value}`);
const children = await response.json();
return children.map((child) => ({
label: child.name,
value: child.id,
isLeaf: !child.hasChildren,
}));
};
const AsyncTreeSelect = () => {
const [treeData, setTreeData] = useState([]);
useEffect(() => {
const fetchData = async () => {
const response = await fetch('/api/root');
const root = await response.json();
setTreeData([
{
label: root.name,
value: root.id,
isLeaf: !root.hasChildren,
},
]);
};
fetchData();
}, []);
return (
<TreeSelect
treeData={treeData}
loadData={loadData}
placeholder="请选择"
/>
);
};
export default AsyncTreeSelect;
```
在上面的示例代码中,我们定义了一个 `loadData` 异步函数,用于加载树的子节点数据。在 `loadData` 函数中,我们通过发送异步请求获取当前节点的子节点数据,然后将其格式化为 TreeSelect 能够识别的数据格式,并将其作为函数的返回值返回。
在组件中,我们通过 `useEffect` 钩子和 `fetch` 函数获取根节点数据,并将其格式化为 TreeSelect 能够识别的数据格式。然后,我们将根节点数据作为 `treeData` 属性传递给 TreeSelect 组件,并将 `loadData` 函数作为 `loadData` 属性传递给 TreeSelect 组件,用于异步加载子节点数据。
需要注意的是,`loadData` 函数中需要将子节点的 `isLeaf` 属性设置为 `true` 或 `false`,以告诉 TreeSelect 组件是否还有子节点。如果当前节点没有子节点,则应将其 `isLeaf` 属性设置为 `true`。
阅读全文