如何制作切换列表 vue-select?
How to make a toggle list vue-select?
我需要确保当你点击一个已经激活的选项时,它会变成取消选择。
<v-select class="form-control" name="language" v-model="language" id="language" :options="['English', 'Polish']" :clearable="false" :searchable="false" :multiple="true" :closeOnSelect="false"></v-select>
Photo Example
我在 Internet 和文档中找不到这方面的信息,因此希望得到您的帮助。
vue-select
包中没有任何内置方式或道具来取消选择项目,但是有两种方法可以解决它:
1)您可以使用 (option:selecting) 事件自行过滤数组,从而取消选择该选项。查看下面的示例。
<template>
<div>
<v-select
class="form-control"
name="language"
v-model="language"
id="language"
:options="['English', 'Polish']"
:clearable="false"
:searchable="false"
:multiple="true"
:closeOnSelect="false"
@option:selecting="handleDeselect"
></v-select>
<div class="mt-40">Languages is : {{ language }}</div>
</div>
</template>
<script>
import vSelect from "vue-select";
import "vue-select/dist/vue-select.css";
export default {
components: { vSelect },
data() {
return {
language: ["English"],
};
},
methods: {
handleDeselect(e) {
// Check if the lagueage array contains the selected element (e)
// If so, filter the language array
if (this.language.includes(e)) {
this.language = this.language.filter((el) => {
return el != e;
});
}
},
},
};
</script>
2)使用 vue-multiselect
包,它提供开箱即用的取消选择功能(最简单也是我的首选方式)
我需要确保当你点击一个已经激活的选项时,它会变成取消选择。
<v-select class="form-control" name="language" v-model="language" id="language" :options="['English', 'Polish']" :clearable="false" :searchable="false" :multiple="true" :closeOnSelect="false"></v-select>
Photo Example
我在 Internet 和文档中找不到这方面的信息,因此希望得到您的帮助。
vue-select
包中没有任何内置方式或道具来取消选择项目,但是有两种方法可以解决它:
1)您可以使用 (option:selecting) 事件自行过滤数组,从而取消选择该选项。查看下面的示例。
<template>
<div>
<v-select
class="form-control"
name="language"
v-model="language"
id="language"
:options="['English', 'Polish']"
:clearable="false"
:searchable="false"
:multiple="true"
:closeOnSelect="false"
@option:selecting="handleDeselect"
></v-select>
<div class="mt-40">Languages is : {{ language }}</div>
</div>
</template>
<script>
import vSelect from "vue-select";
import "vue-select/dist/vue-select.css";
export default {
components: { vSelect },
data() {
return {
language: ["English"],
};
},
methods: {
handleDeselect(e) {
// Check if the lagueage array contains the selected element (e)
// If so, filter the language array
if (this.language.includes(e)) {
this.language = this.language.filter((el) => {
return el != e;
});
}
},
},
};
</script>
2)使用 vue-multiselect
包,它提供开箱即用的取消选择功能(最简单也是我的首选方式)