Element UI框架中巧用樹選擇器的實(shí)現(xiàn)
本文介紹了Element UI框架中巧用樹選擇器的實(shí)現(xiàn),分享給大家,順便給自己留個(gè)筆記,具體如下:

介紹
在Element UI框架中有選擇器和樹形控件,但是沒有樹形選擇器,也就是圖上的這種方式的選擇器,所以只能自定義選擇器的slot。這里介紹的是多選情況,如果是單選則去掉復(fù)選框,修改一部分的處理即可。
html部分的代碼:
<el-select
v-model="dataArr"
:multiple="multiple"
filterable
:placeholder="placeholder"
:disabled="disabled"
:collapse-tags="multiple"
@remove-tag="handleTagChange"
@visible-change="handleOptionHidden"
class="hi-input">
<el-option value="0"
class="hidden">
</el-option>
<!--el-tree綁定的數(shù)組中children里的key值不能是0-->
<el-tree
ref="tree"
:data="options"
node-key="key"
show-checkbox
:default-checked-keys="selectedData"
@check="handleCheckChange"
:props="defaultProps">
</el-tree>
</el-select>
在el-tree中綁定的值是已選擇的key值組成的數(shù)組,check綁定的事件函數(shù)是為了:
- 得到現(xiàn)在樹選擇器上選中的值
- 過濾undefined、null的值(是為了容錯(cuò)處理) 具體代碼如下:
handleCheckChange: function() {
this.selectedData = this.$refs.tree.getCheckedKeys().filter(_ => _);
}
因?yàn)檫x擇器是有l(wèi)abel值和key值區(qū)分的,所以,每當(dāng)在el-tree中選中值key值變化時(shí),選擇器上綁定的值label值也應(yīng)該隨之變化,所以在watch中監(jiān)聽key值,目的是在el-tree綁定的data中找到當(dāng)前key值對應(yīng)的label值 具體代碼如下:
watch: {
selectedData: function(newValue) {
this.$nextTick(() => { this.dataArr = this.handleDataTransform(newValue, 'key', 'label'); });
},
},
methods: {
getNameById(array, value, id, name, multi) {
let arr = array || [];
let flag;
let result = arr.filter(item => {
return item[id] + '' === value + '';
});
if (multi) {
flag = result.map(item => {
return item[name];
});
} else {
let obj = result[0];
flag = name ? obj && obj[name] : obj;
}
return flag;
},
handleDataTransform: function(source, key, value) {
return this.options.map(_ => {
let arr = source.map(item => this.$util.getNameById(
_.children,
item,
key,
value
)).filter(item => item);
return arr;
}).reduce((acc, cur) => {
return acc.concat(cur);
}, []);
}
}
到這里為止,已經(jīng)完成了樹形控件到選擇器的單向綁定,現(xiàn)在處理選擇器的值發(fā)生改變時(shí),樹形控件也變化。因?yàn)榇藭r(shí)是多選,所以要在remove-tag事件中處理,具體代碼如下:
handleTagChange: function() {
// handleDataTransform已經(jīng)在之前定義過
this.selectedData = this.handleDataTransform(this.dataArr, 'label', 'key');
this.$refs.tree.setCheckedKeys(this.selectedData);
},
此時(shí),這個(gè)樹形選擇器已經(jīng)完成了~:clap::clap:,但是,我們還可以進(jìn)一步優(yōu)化,比如:如果選擇后的內(nèi)容與選擇前的內(nèi)容一樣,不再發(fā)生請求的處理。 在選擇器中綁定的visible-change事件可以處理,思想是:
- item值為true,即展開下拉框時(shí),把此時(shí)的值存儲(chǔ)下來,注意:warning::這時(shí)候存儲(chǔ)下來的值必須放在一個(gè)全局變量中,函數(shù)內(nèi)的變量會(huì)在每次進(jìn)入這個(gè)函數(shù)時(shí)初始化,所以在下拉框收起再進(jìn)來這個(gè)函數(shù)時(shí),之前存儲(chǔ)的值已經(jīng)沒有了。
- item值為false,即收起下拉框時(shí),判斷之前存儲(chǔ)下的變量值和當(dāng)前變量值是否相等,如果不相等才觸發(fā)數(shù)據(jù)的更新。 具體代碼如下:
handleOptionHidden: function(item) {
// 處理選中內(nèi)容沒變的情況
if (item) {
this.selectedItem = [...this.selectedData];
} else {
// this.$util.isEqual()是判斷兩個(gè)數(shù)組是否相等函數(shù),網(wǎng)上很多,請自行谷歌
if (!this.$util.isEqual(this.selectedItem, this.selectedData)) {
this.handleUpdate(this.selectedData);
}
}
},
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
詳解vuex中的this.$store.dispatch方法
這篇文章主要介紹了vuex中的this.$store.dispatch方法,必須要用commit(‘SET_TOKEN’,?tokenV)調(diào)用mutations里的方法,才能在store存儲(chǔ)成功,需要的朋友可以參考下2022-11-11
Vue一個(gè)動(dòng)態(tài)添加background-image的實(shí)現(xiàn)
這篇文章主要介紹了Vue一個(gè)動(dòng)態(tài)添加background-image的實(shí)現(xiàn)方式,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-03-03
vue本地構(gòu)建熱更新卡頓的問題“75?advanced?module?optimization”完美解決方案
這篇文章主要介紹了vue本地構(gòu)建熱更新卡頓的問題“75?advanced?module?optimization”解決方案,每次熱更新都會(huì)卡在?"75?advanced?module?optimization"?的地方不動(dòng)了,如何解決這個(gè)問題呢,下面小編給大家?guī)砹私鉀Q方案,需要的朋友可以參考下2022-08-08
Vue 動(dòng)態(tài)添加路由及生成菜單的方法示例
這篇文章主要介紹了Vue 動(dòng)態(tài)添加路由及生成菜單的方法示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-06-06
淺談在vue項(xiàng)目中如何定義全局變量和全局函數(shù)
本篇文章主要介紹了淺談在vue項(xiàng)目中如何定義全局變量和全局函數(shù),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-10-10
vue watch監(jiān)聽取不到this指向的數(shù)問題
這篇文章主要介紹了vue watch監(jiān)聽取不到this指向的數(shù)問題,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-09-09

