最近在前端開發(fā)中遇到了一個(gè)vue多選樹形組件的需求,通過調(diào)研和使用,發(fā)現(xiàn)了一個(gè)比較好用的開源組件——vue-tree-multiselect。
vue-tree-multiselect是一個(gè)基于Vue.js的、支持多選的樹形選擇器,它采用Bootstrap的樣式和Font Awesome圖標(biāo)庫,支持異步加載數(shù)據(jù),可以嵌套無限層級(jí)的樹形結(jié)構(gòu),支持搜索、清空選擇等常用功能。
//安裝vue-tree-multiselect npm install vue-tree-multiselect --save
使用vue-tree-multiselect也非常簡單,只需要在組件中引入并掛載即可。
import VueTreeMultiselect from 'vue-tree-multiselect';
export default {
components: {
VueTreeMultiselect,
},
data() {
return {
options: [
{
label: 'Parent Node 1',
id: 1,
children: [
{
label: 'Child Node 1',
id: 2,
},
{
label: 'Child Node 2',
id: 3,
},
],
},
{
label: 'Parent Node 2',
id: 4,
children: [
{
label: 'Child Node 3',
id: 5,
},
{
label: 'Child Node 4',
id: 6,
},
],
},
],
value: [],
};
},
}
上面的代碼中,我們首先通過npm安裝了vue-tree-multiselect組件,然后在組件中引入了它,將它作為子組件,并在data中定義了選擇器中的選項(xiàng)(options)和已選中的值(value)。
接下來,在模板中進(jìn)行掛載,將選項(xiàng)傳入vue-tree-multiselect組件中,設(shè)置value為一個(gè)選項(xiàng)的id數(shù)組,即可實(shí)現(xiàn)樹形選擇器。
上面的代碼中,我們?cè)O(shè)置了多選(multiple)、初始化時(shí)顯示下拉框(show-drop-down-on-init)和允許未分類的選項(xiàng)(allow-uncategorized)等屬性,可以根據(jù)實(shí)際需要進(jìn)行調(diào)整。
使用vue-tree-multiselect還可以通過slot插槽來自定義選項(xiàng)的展示方式,比如可以加入checkbox、icon等元素,以滿足各種不同的業(yè)務(wù)需求。
最后,需要注意的是,vue-tree-multiselect組件只提供了UI和功能,實(shí)際操作的數(shù)據(jù)、異步加載等需要根據(jù)自己的業(yè)務(wù)邏輯進(jìn)行實(shí)現(xiàn)。