本文介紹了Element UI框架中巧用樹選擇器的實(shí)現(xiàn),分享給大家,順便給自己留個(gè)筆記,具體如下:
創(chuàng)新互聯(lián)公司是一家專業(yè)提供鷹潭企業(yè)網(wǎng)站建設(shè),專注與成都網(wǎng)站設(shè)計(jì)、網(wǎng)站建設(shè)、H5技術(shù)、小程序制作等業(yè)務(wù)。10年已為鷹潭眾多企業(yè)、政府機(jī)構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專業(yè)網(wǎng)站建設(shè)公司優(yōu)惠進(jìn)行中。
介紹
在Element UI框架中有選擇器和樹形控件,但是沒有樹形選擇器,也就是圖上的這種方式的選擇器,所以只能自定義選擇器的slot。這里介紹的是多選情況,如果是單選則去掉復(fù)選框,修改一部分的處理即可。
html部分的代碼:
在el-tree中綁定的值是已選擇的key值組成的數(shù)組,check綁定的事件函數(shù)是為了:
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值對(duì)應(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ā)生請(qǐng)求的處理。 在選擇器中綁定的visible-change事件可以處理,思想是:
handleOptionHidden: function(item) { // 處理選中內(nèi)容沒變的情況 if (item) { this.selectedItem = [...this.selectedData]; } else { // this.$util.isEqual()是判斷兩個(gè)數(shù)組是否相等函數(shù),網(wǎng)上很多,請(qǐng)自行谷歌 if (!this.$util.isEqual(this.selectedItem, this.selectedData)) { this.handleUpdate(this.selectedData); } } },
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。