詳解Vue Elementui中的Tag與頁面其它元素相互交互的兩三事
前言
公司系統(tǒng)在用elementui做后臺(tái)開發(fā),不免遇到一些需要自己去根據(jù)原有的功能上,加一些交互的功能。
今天來介紹下我在用elementUi里的Tag標(biāo)簽與多選框交互的過程,東西聽上去很簡單,但就是越簡單的東西越容易出一些問題。官方tag文檔:elementUi-tag標(biāo)簽
效果圖:

思路
一、多選框勾選,出現(xiàn)對應(yīng)的tag:
1.利用watch監(jiān)聽多選框綁定的值A(chǔ)(數(shù)組)的變化;
2.根據(jù)A的變化,循環(huán)拿到勾選多選框的id對應(yīng)的name,將id以及對應(yīng)的name組成新的對象數(shù)組;
3.將上一步得到的對象數(shù)組,去重(產(chǎn)品要求,出現(xiàn)的tag里不能有重復(fù)的)得到結(jié)果B;
4.將B賦值給tags,循環(huán)展示出來;
二、點(diǎn)擊tag上的刪除按鈕,刪除當(dāng)前的tag,并將對應(yīng)勾選的多選框取消勾選:
1.點(diǎn)擊tag刪除的按鈕的時(shí)候,拿到當(dāng)前tag的id C;
2.執(zhí)行方法,去除掉A里的C;
3.watch事件重新進(jìn)入到第一步的方法;
總結(jié):監(jiān)聽多選框?qū)?yīng)的model A,根據(jù)A的變化,取到對應(yīng)的id與name,賦值給tag作展示,tag的刪除事件反過來在去控制A的變化,重新進(jìn)入watch事件里的方法
聽起來挺簡單,思路大概也明確,先講上述思路對應(yīng)的代碼,后邊再講遇到的問題、坑
代碼
復(fù)制整一塊代碼到你的elementUi項(xiàng)目里就能看到效果
<template>
<div>
<el-row type="flex" justify="bettwen">
<el-col :span="15">
<!-- 表單 -->
<el-form :model="tempForm" ref="tempForms">
<el-form-item label="請選擇人員">
<!-- 多選人員 -->
<el-checkbox-group v-model="tempForm.checkboxGroup5" size="small">
<el-checkbox border v-for="(item,index) in checkBox" @change="perChange(item)" :label="item.id" :key="index">{{item.name}}</el-checkbox>
</el-checkbox-group>
<!-- 多選人員 end-->
</el-form-item>
</el-form>
<!-- 表單 end-->
<!-- tag展示區(qū) -->
<el-row>
<el-tag class="tagClass" v-for="(tag,index) in tags" :key="index" closable @close="handleClose(tag)" :type="tag.id">
{{tag.name}}
</el-tag>
<el-button v-if="tags.length>0" @click="clearAll" plain>全部刪除</el-button>
</el-row>
<!-- tag展示區(qū) end-->
</el-col>
</el-row>
</div>
</template>
<script>
export default {
name: 'kk',
mounted() {},
data() {
return {
msg: 'Welcome to Your Vue.js App',
tags: [],
tempForm: {
checkboxGroup5: [], //選擇的人員
},
detailData: [],
checkBox: [{
name: '小紅',
id: '101'
},
{
name: '小黃',
id: '100'
}, {
name: '小明',
id: '102'
}, {
name: '小明',
id: '102'
}
],
}
},
methods: {
clearAll() { //全部清空數(shù)據(jù)
this.tags = []
this.tempForm.checkboxGroup5 = []
},
perChange(item) {
this.detailData.push(item)
},
handleClose(tag) { //標(biāo)簽的刪除事件
// 去掉當(dāng)前刪除的tag
let yourChoseTags = this.tempForm.checkboxGroup5
this.tempForm.checkboxGroup5 = yourChoseTags.filter(item => {
if (tag.id !== item) {
return true
}
})
},
delRepeat(arr) { //數(shù)組對象去重
return Object.values(
arr.reduce((obj, next) => {
var key = JSON.stringify(next);
return (obj[key] = next), obj;
}, {}),
);
},
moreArr() {
let yourChose = this.tempForm.checkboxGroup5
let tempTags = []
tempTags = this.baseDataDetail(yourChose, this.checkBox, tempTags)
this.detailData = tempTags
},
baseDataDetail(yourChose, baseData, callBack) { //封裝的數(shù)組方法
let temp = callBack
// 循環(huán)兩個(gè)數(shù)據(jù)拿到選擇的checkbox的id對應(yīng)的初始數(shù)據(jù)
yourChose.forEach(item => {
baseData.forEach(itemSecond => {
if (item === itemSecond.id) {
temp.push(itemSecond)
}
})
})
return temp
},
},
watch: {
detailData() {
let tempArr = Object.assign([], this.detailData)
tempArr = this.delRepeat(tempArr)
// console.log(tempArr)
this.tags = tempArr
},
"tempForm.checkboxGroup5" () {
this.moreArr()
},
}
}
</script>
<!-- Add "scoped" attribute to limit CSS to this component only -->
<style scoped>
.tempArea {
/*width: 100%;*/
}
.tagClass{
margin-right: 10px;
}
</style>
值得注意的點(diǎn):
1.我在多選框綁定值tempForm.checkboxGroup5的監(jiān)聽事件里的方法的最后,得到了一個(gè)可能會(huì)有重復(fù)數(shù)據(jù)(重復(fù)id跟name),再將這個(gè)含有重復(fù)數(shù)據(jù)數(shù)組對象賦值給另一個(gè)數(shù)組detailData,在watch監(jiān)聽這個(gè)數(shù)組,去完重后,賦值給tags做展示。
為什么這樣做,是因?yàn)?,我們的需求里,除了在?dāng)前頁面多選框選擇人員,還有一個(gè)選擇全公司員工的組件,這樣不管從哪個(gè)渠道選擇的人員都能最后將結(jié)果指向detailData,保證渲染正確
2.數(shù)組對象去重,初始數(shù)據(jù)里可能會(huì)有重id、重名的對象(小明),即便綁定多選框的model值里不會(huì)有重復(fù)的id,但在 利用id取對應(yīng)name的時(shí)候,還是會(huì)檢測出多條,這樣tag就可能會(huì)顯示重復(fù)的
所以利用這個(gè)方法,就能保證最后處理好的數(shù)據(jù)沒有重復(fù)的,tag不會(huì)顯示多個(gè)一樣的,
但這個(gè)方法有點(diǎn)不靈活的地方就是,你要處理的數(shù)據(jù)({id:1,name:'小明',type:now})必須id、name,type都重復(fù)的時(shí)候,才會(huì)被去重,
拓展:可根據(jù)你設(shè)置的數(shù)組對象里的某個(gè)屬性動(dòng)態(tài)去重
3.我一開始是在多選框的change事件上來做tag的展示邏輯,因?yàn)閏hange事件里可以同時(shí)拿到當(dāng)前選擇的name和id,但是,change的時(shí)候,你不知道這是在勾選還是在取消勾選,這樣tags的展示就會(huì)出問題;
這個(gè)邏輯可能不太完美,因?yàn)橛锌赡苣愕娜藛T是從其他組件里選來的,所以當(dāng)你刪除tag的時(shí)候,會(huì)可能出問題(暫時(shí)先不討論這種情況)
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Vue el-table組件如何實(shí)現(xiàn)將日期格式化
這篇文章主要介紹了Vue el-table組件如何實(shí)現(xiàn)將日期格式化問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-04-04
Vue Render函數(shù)創(chuàng)建DOM節(jié)點(diǎn)代碼實(shí)例
這篇文章主要介紹了Vue Render函數(shù)創(chuàng)建DOM節(jié)點(diǎn)代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-07-07
五種Vue實(shí)現(xiàn)加減乘除運(yùn)算的方法總結(jié)
這篇文章主要為大家詳細(xì)介紹了五種Vue實(shí)現(xiàn)加減乘除運(yùn)算的方法,文中的示例代碼簡潔易懂,對我們深入了解vue有一定的幫助,需要的可以了解下2023-08-08
vue實(shí)現(xiàn)公共組件傳值并及時(shí)監(jiān)聽到數(shù)據(jù)更新視圖
這篇文章主要介紹了vue實(shí)現(xiàn)公共組件傳值并及時(shí)監(jiān)聽到數(shù)據(jù)更新視圖方式,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-01-01
Vue動(dòng)態(tài)改變css樣式的3種方法總結(jié)
這篇文章主要給大家介紹了關(guān)于Vue動(dòng)態(tài)改變css樣式的3種方法,在Vue.js中我們經(jīng)常需要根據(jù)特定的條件或事件來動(dòng)態(tài)地修改CSS樣式,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-11-11
解決vue刷新頁面以后丟失store的數(shù)據(jù)問題
這篇文章主要介紹了解決vue刷新頁面以后丟失store的數(shù)據(jù)問題,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-08-08
如何在vue-cli中使用css-loader實(shí)現(xiàn)css module
這篇文章主要介紹了如何在vue-cli中使用css-loader實(shí)現(xiàn)css module,幫助大家更好的理解和使用vue框架,感興趣的朋友可以了解下2021-01-01

