iview/examples/routers/cascader.vue

67 lines
2.1 KiB
Vue
Raw Normal View History

2017-03-06 17:30:39 +08:00
<template>
2017-05-09 15:46:08 +08:00
<Row>
<i-col span="4">
<Button @click="handleLoad">load</Button>
</i-col>
<i-col span="6">
<!--<Cascader :data="data2" v-model="v1" change-on-select></Cascader>-->
<Cascader :data="data2" v-model="v1" :loadData="loadData"></Cascader>
</i-col>
</Row>
</template>
<script>
export default {
data () {
return {
2017-05-09 15:46:08 +08:00
v1: [],
2017-04-10 22:43:24 +08:00
data2: [{
value: 'zhejiang',
label: '浙江',
2017-05-09 15:46:08 +08:00
children: [],
loading: false
2017-04-10 22:43:24 +08:00
}, {
value: 'jiangsu',
label: '江苏',
children: [{
2017-04-01 10:22:34 +08:00
value: 'nanjing',
label: '南京',
2017-04-10 22:43:24 +08:00
children: [{
value: 'zhonghuamen',
label: '中华门'
}]
}]
}]
}
2017-05-09 15:46:08 +08:00
},
methods: {
handleLoad () {
this.data2[0].loading = !this.data2[0].loading;
},
loadData (item, cb) {
item.loading = true;
setTimeout(() => {
if (item.value === 'zhejiang') {
item.children = [
{
value: 'hangzhou',
label: '杭州',
loading: false,
children: []
}
];
} else if (item.value === 'hangzhou') {
item.children = [
{
value: 'ali',
label: '阿里巴巴'
}
];
}
item.loading = false;
cb();
}, 1000);
}
}
}
</script>