iview/examples/routers/select.vue

79 lines
2.6 KiB
Vue
Raw Normal View History

<template>
2017-07-20 11:53:18 +08:00
<i-select transfer multiple v-model="m1">
<i-option v-for="item in options" :value="item.value" :key="item.value">{{ item.label }}</i-option>
</i-select>
</template>
<script>
export default {
data () {
return {
2017-07-20 11:53:18 +08:00
m1: [],
showModal: false,
showModal2: false,
options: [
{
value: 'beijing',
label: '北京市'
},
{
value: 'shanghai',
label: '上海市'
},
{
value: 'shenzhen',
label: '深圳市'
},
{
value: 'hangzhou',
label: '杭州市'
},
{
value: 'nanjing',
label: '南京市'
},
{
value: 'chongqing',
label: '重庆市'
}
]
2017-05-05 14:20:46 +08:00
}
},
methods: {
2017-07-14 13:58:34 +08:00
remoteMethod1 (query) {
2017-05-31 13:59:14 +08:00
if (query !== '') {
2017-07-14 13:58:34 +08:00
this.loading1 = true;
2017-05-31 13:59:14 +08:00
setTimeout(() => {
2017-07-14 13:58:34 +08:00
this.loading1 = false;
const list = this.list.map(item => {
return {
value: item,
label: item
};
2017-05-31 13:59:14 +08:00
});
2017-07-14 13:58:34 +08:00
this.options1 = list.filter(item => item.label.toLowerCase().indexOf(query.toLowerCase()) > -1);
}, 200);
2017-05-31 13:59:14 +08:00
} else {
2017-07-14 13:58:34 +08:00
this.options1 = [];
2017-05-31 13:59:14 +08:00
}
},
2017-07-14 13:58:34 +08:00
remoteMethod2 (query) {
if (query !== '') {
this.loading2 = true;
setTimeout(() => {
this.loading2 = false;
const list = this.list.map(item => {
return {
value: item,
label: item
};
});
this.options2 = list.filter(item => item.label.toLowerCase().indexOf(query.toLowerCase()) > -1);
}, 200);
} else {
this.options2 = [];
}
}
}
}
2017-05-19 10:49:47 +08:00
</script>