# 异步数据加载 - order: 3 异步加载数据 --- ````jsx var Tree = antd.Tree; var TreeNode = Tree.TreeNode; const asyncTree = [ {name: "pNode 01", key: "0-0"}, ]; const generateTreeNodes = () => { const arr = [ {name: "伯约", key: "0-0-0"}, ]; return arr; } const TreeDemo = React.createClass({ propTypes: {}, timeout(duration = 0) { return new Promise((resolve, reject) => { setTimeout(resolve.bind(this), duration); }) }, getInitialState() { return { treeData: [] }; }, componentDidMount() { this.timeout(1000).then(() => { this.setState({ treeData: asyncTree }); return asyncTree; }); }, handleSelect(info) { console.log('selected', info); }, handleDataLoaded(treeNode) { return this.timeout(1000).then(() => { const child = generateTreeNodes(); const treeData = [...this.state.treeData]; treeData.forEach((item) => { if (item.key === treeNode.props.eventKey) { item.children = child; } }); this.setState({treeData}); return child; }); }, render() { const loop = (data) => { return data.map((item) => { if (item.children) { return {loop(item.children)}; } else { return ; } }) }; const parseTreeNode = data => loop(data); let treeNodes = parseTreeNode(this.state.treeData); return ( {treeNodes} ) } }) ReactDOM.render(, document.getElementById('components-tree-demo-dynamic')); ````