av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術文章
文章詳情頁

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

瀏覽:7日期:2023-01-06 10:18:16

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

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

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

//html <li> <span class='fill-title'>與我相關</span> <div> <van-button v-for='(item, index) in myself' :key='index' @click='checkButton(’myself’, item.id)' : >{{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)' : >{{item.title}}</van-button> </div> </li>

數據

myself: [ { id: 1,title: '親屬', isFlag: false }, {id: 2,title: '同鄉(xiāng)',isFlag: false}, {id: 3, title: '同學',isFlag: false }, {id: 4,title: '同事', isFlag: false},], biaoqian: [ {id: 1, title: '已婚',type: 1,isFlag: false }, {id: 2,title: '單身',type: 1,isFlag: false }, {id: 3,title: '有娃',isFlag: false }, {id: 4,title: '有房', isFlag: false }, {id: 5,title: '有車',isFlag: false}, {id: 6,title: '不了解保險',isFlag: false,type: 2}, {id: 7,title: '已了解保險',isFlag: false,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 記錄當前標簽狀態(tài)是否選中,為了取消標簽狀態(tài) 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點擊標簽切換選中及互相排斥操作就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Vue
相關文章:
主站蜘蛛池模板: 国产一区精品在线 | 久久这里只有精品首页 | 欧美一级黄色片免费观看 | 久久精品久久精品久久精品 | 日韩欧美一级片 | www.久久99 | 亚洲三区在线 | 国产成人免费视频网站高清观看视频 | 91在线视频免费观看 | 午夜成人免费视频 | 在线中文字幕av | aaa大片免费观看 | 亚洲视频在线看 | 国产精品欧美一区二区三区不卡 | 特级丰满少妇一级aaaa爱毛片 | 成人免费视频 | 亚洲一区二区三区在线视频 | 亚洲a视频 | 成人免费在线观看 | 国产精品美女久久久免费 | 日本在线一二 | 婷婷久| 欧美在线国产精品 | 999久久精品 | 亚洲91视频| 久久大陆 | 国产伦精品一区二区三区精品视频 | 黄色成人国产 | 国产精品网址 | 日韩在线免费播放 | 一区二区免费高清视频 | 91人人在线 | 日韩午夜电影 | 日韩国产专区 | 一区二区久久 | 亚洲午夜三级 | 欧美二区乱c黑人 | 色伊人久久 | 日韩精品免费视频 | 亚洲一二三区精品 | 久久免费精品视频 |