mirror of
https://github.com/ant-design/ant-design.git
synced 2025-01-07 20:08:21 +08:00
112 lines
2.6 KiB
Markdown
112 lines
2.6 KiB
Markdown
---
|
|
order: 3
|
|
title:
|
|
zh-CN: 异步数据加载
|
|
en-US: load data asynchronously
|
|
---
|
|
|
|
## zh-CN
|
|
|
|
点击展开节点,动态加载数据。
|
|
|
|
## en-US
|
|
|
|
To load data asynchronously when click to expand a treeNode.
|
|
|
|
````jsx
|
|
import { Tree } from 'antd';
|
|
const TreeNode = Tree.TreeNode;
|
|
|
|
function generateTreeNodes(treeNode) {
|
|
const arr = [];
|
|
const key = treeNode.props.eventKey;
|
|
for (let i = 0; i < 3; i++) {
|
|
arr.push({ name: `leaf ${key}-${i}`, key: `${key}-${i}` });
|
|
}
|
|
return arr;
|
|
}
|
|
|
|
function setLeaf(treeData, curKey, level) {
|
|
const loopLeaf = (data, lev) => {
|
|
const l = lev - 1;
|
|
data.forEach((item) => {
|
|
if ((item.key.length > curKey.length) ? item.key.indexOf(curKey) !== 0 :
|
|
curKey.indexOf(item.key) !== 0) {
|
|
return;
|
|
}
|
|
if (item.children) {
|
|
loopLeaf(item.children, l);
|
|
} else if (l < 1) {
|
|
item.isLeaf = true;
|
|
}
|
|
});
|
|
};
|
|
loopLeaf(treeData, level + 1);
|
|
}
|
|
|
|
function getNewTreeData(treeData, curKey, child, level) {
|
|
const loop = (data) => {
|
|
if (level < 1 || curKey.length - 3 > level * 2) return;
|
|
data.forEach((item) => {
|
|
if (curKey.indexOf(item.key) === 0) {
|
|
if (item.children) {
|
|
loop(item.children);
|
|
} else {
|
|
item.children = child;
|
|
}
|
|
}
|
|
});
|
|
};
|
|
loop(treeData);
|
|
setLeaf(treeData, curKey, level);
|
|
}
|
|
|
|
const Demo = React.createClass({
|
|
getInitialState() {
|
|
return {
|
|
treeData: [],
|
|
};
|
|
},
|
|
componentDidMount() {
|
|
setTimeout(() => {
|
|
this.setState({
|
|
treeData: [
|
|
{ name: 'pNode 01', key: '0-0' },
|
|
{ name: 'pNode 02', key: '0-1' },
|
|
{ name: 'pNode 03', key: '0-2', isLeaf: true },
|
|
],
|
|
});
|
|
}, 100);
|
|
},
|
|
onSelect(info) {
|
|
console.log('selected', info);
|
|
},
|
|
onLoadData(treeNode) {
|
|
return new Promise((resolve) => {
|
|
setTimeout(() => {
|
|
const treeData = [...this.state.treeData];
|
|
getNewTreeData(treeData, treeNode.props.eventKey, generateTreeNodes(treeNode), 2);
|
|
this.setState({ treeData });
|
|
resolve();
|
|
}, 1000);
|
|
});
|
|
},
|
|
render() {
|
|
const loop = data => data.map((item) => {
|
|
if (item.children) {
|
|
return <TreeNode title={item.name} key={item.key}>{loop(item.children)}</TreeNode>;
|
|
}
|
|
return <TreeNode title={item.name} key={item.key} isLeaf={item.isLeaf} disabled={item.key === '0-0-0'} />;
|
|
});
|
|
const treeNodes = loop(this.state.treeData);
|
|
return (
|
|
<Tree onSelect={this.onSelect} loadData={this.onLoadData}>
|
|
{treeNodes}
|
|
</Tree>
|
|
);
|
|
},
|
|
});
|
|
|
|
ReactDOM.render(<Demo />, mountNode);
|
|
````
|