2020-02-04 21:44:48 +08:00
|
|
|
# Async Single
|
2019-10-23 13:56:20 +08:00
|
|
|
```html
|
|
|
|
<n-cascader
|
|
|
|
v-model="value"
|
|
|
|
placeholder="Please Select Something"
|
|
|
|
:options="options"
|
2019-10-23 16:51:29 +08:00
|
|
|
:leaf-only="false"
|
2020-02-04 21:44:48 +08:00
|
|
|
remote
|
2019-10-23 13:56:20 +08:00
|
|
|
:on-load="handleLoad"
|
|
|
|
/>
|
|
|
|
```
|
|
|
|
```js
|
|
|
|
function genChildren (option) {
|
|
|
|
const children = []
|
|
|
|
for (let i = 0; i <= option.depth; ++i) {
|
|
|
|
children.push({
|
|
|
|
label: option.label + '_' + i,
|
|
|
|
value: option.label + '_' + i,
|
|
|
|
isLeaf: option.depth === 3
|
|
|
|
})
|
|
|
|
}
|
|
|
|
return children
|
|
|
|
}
|
|
|
|
|
|
|
|
const options = [
|
|
|
|
{
|
|
|
|
label: 'Root',
|
|
|
|
value: 'root',
|
|
|
|
isLeaf: false
|
|
|
|
}
|
|
|
|
]
|
|
|
|
|
|
|
|
export default {
|
|
|
|
data () {
|
|
|
|
return {
|
|
|
|
value: null,
|
|
|
|
options: options
|
|
|
|
}
|
|
|
|
},
|
|
|
|
methods: {
|
|
|
|
handleLoad (option, resolve) {
|
|
|
|
window.setTimeout(() => {
|
|
|
|
resolve(genChildren(option))
|
|
|
|
}, 1000)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
```
|