欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解Vue Elementui中的Tag與頁面其它元素相互交互的兩三事

 更新時間:2018年09月25日 09:39:38   作者:大師兄  
這篇文章主要介紹了詳解Vue Elementui中的Tag與頁面其它元素相互交互的兩三事,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

前言

公司系統(tǒng)在用elementui做后臺開發(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)展示出來;

二、點擊tag上的刪除按鈕,刪除當(dāng)前的tag,并將對應(yīng)勾選的多選框取消勾選:

1.點擊tag刪除的按鈕的時候,拿到當(dāng)前tag的id C;
2.執(zhí)行方法,去除掉A里的C;
3.watch事件重新進入到第一步的方法;

總結(jié):監(jiān)聽多選框?qū)?yīng)的model A,根據(jù)A的變化,取到對應(yīng)的id與name,賦值給tag作展示,tag的刪除事件反過來在去控制A的變化,重新進入watch事件里的方法

聽起來挺簡單,思路大概也明確,先講上述思路對應(yīng)的代碼,后邊再講遇到的問題、坑

代碼

復(fù)制整一塊代碼到你的elementUi項目里就能看到效果
<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)兩個數(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>

值得注意的點:

1.我在多選框綁定值tempForm.checkboxGroup5的監(jiān)聽事件里的方法的最后,得到了一個可能會有重復(fù)數(shù)據(jù)(重復(fù)id跟name),再將這個含有重復(fù)數(shù)據(jù)數(shù)組對象賦值給另一個數(shù)組detailData,在watch監(jiān)聽這個數(shù)組,去完重后,賦值給tags做展示。
為什么這樣做,是因為,我們的需求里,除了在當(dāng)前頁面多選框選擇人員,還有一個選擇全公司員工的組件,這樣不管從哪個渠道選擇的人員都能最后將結(jié)果指向detailData,保證渲染正確

2.數(shù)組對象去重,初始數(shù)據(jù)里可能會有重id、重名的對象(小明),即便綁定多選框的model值里不會有重復(fù)的id,但在 利用id取對應(yīng)name的時候,還是會檢測出多條,這樣tag就可能會顯示重復(fù)的
所以利用這個方法,就能保證最后處理好的數(shù)據(jù)沒有重復(fù)的,tag不會顯示多個一樣的,
但這個方法有點不靈活的地方就是,你要處理的數(shù)據(jù)({id:1,name:'小明',type:now})必須id、name,type都重復(fù)的時候,才會被去重,
拓展:可根據(jù)你設(shè)置的數(shù)組對象里的某個屬性動態(tài)去重

3.我一開始是在多選框的change事件上來做tag的展示邏輯,因為change事件里可以同時拿到當(dāng)前選擇的name和id,但是,change的時候,你不知道這是在勾選還是在取消勾選,這樣tags的展示就會出問題;

這個邏輯可能不太完美,因為有可能你的人員是從其他組件里選來的,所以當(dāng)你刪除tag的時候,會可能出問題(暫時先不討論這種情況)

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Vue 的 v-model用法實例

    Vue 的 v-model用法實例

    這篇文章主要介紹了Vue 的 v-model用法實例,幫助大家更好的理解和使用vue,感興趣的朋友可以了解下
    2020-11-11
  • Vue指令之v-for的使用說明

    Vue指令之v-for的使用說明

    這篇文章主要介紹了Vue指令之v-for的使用說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • 詳解如何在vue項目中使用eslint+prettier格式化代碼

    詳解如何在vue項目中使用eslint+prettier格式化代碼

    在開發(fā)中我們需要一種能夠統(tǒng)一團隊代碼風(fēng)格的工具,作為強制性的規(guī)范,統(tǒng)一整個項目的代碼風(fēng)格,這篇文章主要介紹了詳解如何在vue項目中使用eslint+prettier格式化代碼,需要的朋友可以參考下
    2018-11-11
  • Vue.js中extend選項和delimiters選項的比較

    Vue.js中extend選項和delimiters選項的比較

    這篇文章主要介紹了Vue.js中extend選項和delimiters選項的比較的相關(guān)資料,需要的朋友可以參考下
    2017-07-07
  • vue-drag-resize與輸入框/文本框沖突問題

    vue-drag-resize與輸入框/文本框沖突問題

    這篇文章主要介紹了vue-drag-resize與輸入框/文本框沖突問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • vue組件中的樣式屬性scoped實例詳解

    vue組件中的樣式屬性scoped實例詳解

    vue組件中的style標(biāo)簽標(biāo)有scoped屬性時表明style里的css樣式只適用于當(dāng)前組件元素 。接下來通過本文給大家分享vue組件中的樣式屬性scoped實例詳解,感興趣的朋友跟隨小編一起看看吧
    2018-10-10
  • 淺談vue方法內(nèi)的方法使用this的問題

    淺談vue方法內(nèi)的方法使用this的問題

    今天小編就為大家分享一篇淺談vue方法內(nèi)的方法使用this的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • vue組件之間的數(shù)據(jù)傳遞方法詳解

    vue組件之間的數(shù)據(jù)傳遞方法詳解

    這篇文章主要介紹了vue組件之間的數(shù)據(jù)傳遞方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • vue中cookies的使用方式

    vue中cookies的使用方式

    這篇文章主要介紹了vue中cookies的使用方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-08-08
  • vue+axios+mock.js環(huán)境搭建的方法步驟

    vue+axios+mock.js環(huán)境搭建的方法步驟

    本篇文章主要介紹了vue+axios+mock.js環(huán)境搭建的方法步驟,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-08-08

最新評論