import React, { useState } from 'react'; import { Tree } from 'antd'; import type { TreeDataNode, TreeProps } from 'antd'; const treeData: TreeDataNode[] = [ { title: '0-0', key: '0-0', children: [ { title: '0-0-0', key: '0-0-0', children: [ { title: '0-0-0-0', key: '0-0-0-0' }, { title: '0-0-0-1', key: '0-0-0-1' }, { title: '0-0-0-2', key: '0-0-0-2' }, ], }, { title: '0-0-1', key: '0-0-1', children: [ { title: '0-0-1-0', key: '0-0-1-0' }, { title: '0-0-1-1', key: '0-0-1-1' }, { title: '0-0-1-2', key: '0-0-1-2' }, ], }, { title: '0-0-2', key: '0-0-2', }, ], }, { title: '0-1', key: '0-1', children: [ { title: '0-1-0-0', key: '0-1-0-0' }, { title: '0-1-0-1', key: '0-1-0-1' }, { title: '0-1-0-2', key: '0-1-0-2' }, ], }, { title: '0-2', key: '0-2', }, ]; const App: React.FC = () => { const [expandedKeys, setExpandedKeys] = useState<React.Key[]>(['0-0-0', '0-0-1']); const [checkedKeys, setCheckedKeys] = useState<React.Key[]>(['0-0-0']); const [selectedKeys, setSelectedKeys] = useState<React.Key[]>([]); const [autoExpandParent, setAutoExpandParent] = useState<boolean>(true); const onExpand: TreeProps['onExpand'] = (expandedKeysValue) => { console.log('onExpand', expandedKeysValue); // if not set autoExpandParent to false, if children expanded, parent can not collapse. // or, you can remove all expanded children keys. setExpandedKeys(expandedKeysValue); setAutoExpandParent(false); }; const onCheck: TreeProps['onCheck'] = (checkedKeysValue) => { console.log('onCheck', checkedKeysValue); setCheckedKeys(checkedKeysValue as React.Key[]); }; const onSelect: TreeProps['onSelect'] = (selectedKeysValue, info) => { console.log('onSelect', info); setSelectedKeys(selectedKeysValue); }; return ( <Tree checkable onExpand={onExpand} expandedKeys={expandedKeys} autoExpandParent={autoExpandParent} onCheck={onCheck} checkedKeys={checkedKeys} onSelect={onSelect} selectedKeys={selectedKeys} treeData={treeData} /> ); }; export default App;