ant-design/components/tree/demo/special.md

68 lines
1.7 KiB
Markdown
Raw Normal View History

2015-10-15 10:38:14 +08:00
# 接收外部传参
- order: 2
2015-11-27 12:08:57 +08:00
受控组件,外部传入参数,控制树对象节点。
2015-10-15 10:38:14 +08:00
---
````jsx
import { Tree, Button } from 'antd';
const TreeNode = Tree.TreeNode;
2015-10-15 10:38:14 +08:00
class TreeDemo extends React.Component {
constructor(props) {
super(props);
['handleClick', 'handleCheck', 'handleSelect'].forEach((m)=> {
this[m] = this[m].bind(this);
});
this.state = {
checkedKeys: [],
selectedKeys: []
};
2015-10-15 10:38:14 +08:00
}
handleClick() {
this.setState({
checkedKeys: ['p11'],
selectedKeys: ['p21', 'p11']
});
2015-10-15 10:38:14 +08:00
}
handleCheck(info) {
console.log('check: ', info);
this.setState({
checkedKeys: ['p21'],
selectedKeys: ['p1', 'p21']
});
2015-10-15 10:38:14 +08:00
}
handleSelect(info) {
console.log('selected: ', info);
this.setState({
checkedKeys: ['p21'],
selectedKeys: ['p21']
});
2015-10-15 10:38:14 +08:00
}
render() {
return (<div>
2015-11-25 17:47:55 +08:00
<Tree defaultExpandAll checkable
onCheck={this.handleCheck} checkedKeys={this.state.checkedKeys}
onSelect={this.handleSelect} selectedKeys={this.state.selectedKeys} multiple>
<TreeNode title="parent 1" key="p1">
<TreeNode key="p10" title="leaf"/>
<TreeNode title="parent 1-1" key="p11">
<TreeNode title="parent 2-1" key="p21">
2015-11-29 16:54:20 +08:00
<TreeNode title="test" />
<TreeNode title={<span>sss</span>}/>
2015-10-15 10:38:14 +08:00
</TreeNode>
<TreeNode key="p22" title="leaf"/>
2015-10-15 10:38:14 +08:00
</TreeNode>
</TreeNode>
<TreeNode key="p12" title="leaf"/>
</Tree>
2015-10-26 11:02:48 +08:00
<Button type="primary" size="small" onClick={this.handleClick}>点此控制树节点</Button>
2015-10-15 10:38:14 +08:00
</div>);
}
}
ReactDOM.render(<TreeDemo />, mountNode);
2015-10-15 10:38:14 +08:00
````