1. 程式人生 > 程式設計 >vue點選標籤切換選中及互相排斥操作

vue點選標籤切換選中及互相排斥操作

單身和已婚不能同時選中,不瞭解保險和已瞭解保險不能同時選中。

同時各個標籤點選可以取消選擇

vue點選標籤切換選中及互相排斥操作

  //html
  <li>
   <span class="fill-title">與我相關</span>
   <div>
   <van-button
    v-for="(item,index) in myself"
    :key="index"
    @click="checkButton('myself',item.id)"
    :class="item.isFlag ? 'current' : ''"
   >{{item.title}}</van-button>
   </div>
  </li>
  <li>
   <span class="fill-title">標籤</span>
   <div>
   <van-button
    v-for="item in biaoqian"
    :key="item.id"
    @click="checkButton('tag',item.id)"
    :class="item.isFlag ? 'current' : ''"
   >{{item.title}}</van-button>
   </div>
  </li>

資料

  myself: [
  { id: 1,title: "親屬",isFlag: false },{id: 2,title: "同鄉",isFlag: false},{id: 3,title: "同學",{id: 4,title: "同事",],biaoqian: [
  {id: 1,title: "已婚",type: 1,title: "單身",title: "有娃",title: "有房",{id: 5,title: "有車",{id: 6,title: "不瞭解保險",isFlag: false,type: 2},{id: 7,title: "已瞭解保險",type: 2} ],

js

 //標籤只能選中一個
 filterData(arr = [],index) {
  let val = "";
  arr.forEach(item => {
  if (item.id == index) {
   item.isFlag = !item.isFlag;
   val = item.isFlag ? item.title : "";
  } else {
   item.isFlag = false;
  }
  });
  return val;
 },checkButton(val,index) {
  if (val === "tag") {
  let data = [];
  this.biaoqian.forEach(item => {
   if (item.id == index) {
   // a 記錄當前標籤狀態是否選中,為了取消標籤狀態
   let a = item.isFlag;
   item.isFlag = !item.isFlag;
   if (item.type) {
    this.biaoqian.forEach(e => {
    if ((e.type == 1 && index < 3) || (e.type == 2 && index > 5)) {
     //先把同一個型別的標籤都置為false
     e.isFlag = false;
     if (e.id == index) {
     e.isFlag = a ? false : !e.isFlag;
     }
    }
    });
   }
   }
  });
  let arr = this.biaoqian.filter(item => {
   return item.isFlag;
  });
  arr.forEach(item => {
   data.push(item.title);
  });
  this.personItem.labelList = data;
  } else if (val === "sex") {
  this.personItem.sex = this.filterData(this.sexArr,index);
  } else {
  this.personItem.relation = this.filterData(this.myself,index);
  }
 }

補充知識:vue選中與取消簡單實現

我就廢話不多說了,大家還是直接看程式碼吧~

<li v-for="(item,index) in assign" 
  :key="index"
  @click="selected(item)"
  :class="{'active':item.isShow}">

selected(item) {
        if (!item.isShow) {
          item.isShow = true;
          this.selectedList.push(item.id)
        } else {
          item.isShow = false;
          let index = this.selectedList.indexOf(item.id);
          if (index > -1) {
            this.selectedList.splice(index,1);
          }
        }
      },

以上這篇vue點選標籤切換選中及互相排斥操作就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支援我們。