--- order: 3 title: zh-CN: 异步数据加载 en-US: load data asynchronously --- ## zh-CN 点击展开节点,动态加载数据。 ## en-US To load data asynchronously when click to expand a treeNode. ```tsx import React, { useState } from 'react'; import { Tree } from 'antd'; interface DataNode { title: string; key: string; isLeaf?: boolean; children?: DataNode[]; } const initTreeDate: DataNode[] = [ { title: 'Expand to load', key: '0' }, { title: 'Expand to load', key: '1' }, { title: 'Tree Node', key: '2', isLeaf: true }, ]; // It's just a simple demo. You can use tree map to optimize update perf. function updateTreeData(list: DataNode[], key: React.Key, children: DataNode[]): DataNode[] { return list.map(node => { if (node.key === key) { return { ...node, children, }; } else if (node.children) { return { ...node, children: updateTreeData(node.children, key, children), }; } return node; }); } const Demo: React.FC<{}> = () => { const [treeData, setTreeData] = useState(initTreeDate); function onLoadData({ key, children }) { return new Promise(resolve => { if (children) { resolve(); return; } setTimeout(() => { setTreeData(origin => updateTreeData(origin, key, [ { title: 'Child Node', key: `${key}-0` }, { title: 'Child Node', key: `${key}-1` }, ]), ); resolve(); }, 1000); }); } return ; }; class Demo1 extends React.Component { state = { treeData: [ { title: 'Expand to load', key: '0' }, { title: 'Expand to load', key: '1' }, { title: 'Tree Node', key: '2', isLeaf: true }, ], }; onLoadData = treeNode => { const { treeData } = this.state; return new Promise(resolve => { const { props } = treeNode; if (treeNode.children) { resolve(); return; } setTimeout(() => { treeNode.children = [ { title: 'Child Node', key: `${treeNode.eventKey}-0` }, { title: 'Child Node', key: `${treeNode.eventKey}-1` }, ]; this.setState({ treeData: [...this.state.treeData], }); resolve(); }, 1000); }); }; render() { return ; } } ReactDOM.render(, mountNode); ```