mirror of
https://gitee.com/ant-design-vue/ant-design-vue.git
synced 2024-12-02 12:07:54 +08:00
e23265c74c
* refactor: tree-select
57 lines
1.4 KiB
JavaScript
57 lines
1.4 KiB
JavaScript
/* eslint react/no-multi-comp:0, no-console:0 */
|
|
|
|
import BaseMixin from '../../_util/BaseMixin'
|
|
import '../assets/index.less'
|
|
import TreeSelect from '../src/index'
|
|
import { getNewTreeData, generateTreeNodes } from './util'
|
|
|
|
export default {
|
|
mixins: [BaseMixin],
|
|
data: () => ({
|
|
treeData: [
|
|
{ label: 'pNode 01', value: '0-0', key: '0-0' },
|
|
{ label: 'pNode 02', value: '0-1', key: '0-1' },
|
|
{ label: 'pNode 03', value: '0-2', key: '0-2', isLeaf: true },
|
|
],
|
|
// value: '0-0',
|
|
value: { value: '0-0-0-value', label: '0-0-0-label' },
|
|
}),
|
|
methods: {
|
|
onChange (value) {
|
|
console.log(value)
|
|
this.setState({
|
|
value,
|
|
})
|
|
},
|
|
|
|
onLoadData (treeNode) {
|
|
console.log(treeNode)
|
|
return new Promise((resolve) => {
|
|
setTimeout(() => {
|
|
const treeData = [...this.treeData]
|
|
getNewTreeData(treeData, treeNode.eventKey, generateTreeNodes(treeNode), 2)
|
|
this.setState({ treeData })
|
|
resolve()
|
|
}, 500)
|
|
})
|
|
},
|
|
},
|
|
|
|
render () {
|
|
return (
|
|
<div style={{ padding: '10px 30px' }}>
|
|
<h2>dynamic render</h2>
|
|
<TreeSelect
|
|
style={{ width: '300px' }}
|
|
treeData={this.treeData}
|
|
labelInValue
|
|
value={this.value}
|
|
onChange={this.onChange}
|
|
loadData={this.onLoadData}
|
|
__propsSymbol__={Symbol()}
|
|
/>
|
|
</div>
|
|
)
|
|
},
|
|
}
|