vue点击标签切换选中及互相排斥操作


Posted in Javascript onJuly 17, 2020

单身和已婚不能同时选中,不了解保险和已了解保险不能同时选中。

同时各个标签点击可以取消选择

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: "同学",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 记录当前标签状态是否选中,为了取消标签状态
   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点击标签切换选中及互相排斥操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
Javascript里使用Dom操作Xml
Jan 22 Javascript
javascript 函数使用说明
Apr 07 Javascript
JQuery Dialog的内存泄露问题解决方法
Jun 18 Javascript
asp.net+jquery滚动滚动条加载数据的下拉控件
Jun 25 Javascript
js 中{},[]中括号,大括号使用详解
May 12 Javascript
php读取sqlite数据库入门实例代码
Jun 25 Javascript
一个支付页面DEMO附截图
Jul 22 Javascript
js判断当页面无法回退时关闭网页否则就history.go(-1)
Aug 07 Javascript
JavaScript中的索引数组、关联数组和静态数组、动态数组讲解
Nov 08 Javascript
JavaScript多图片上传案例
Sep 28 Javascript
vue.js实现回到顶部动画效果
Jul 31 Javascript
ztree+ajax实现文件树下载功能
May 18 Javascript
Vue点击切换Class变化,实现Active当前样式操作
Jul 17 #Javascript
JS this关键字在ajax中使用出现问题解决方案
Jul 17 #Javascript
vue中v-for循环选中点击的元素并对该元素添加样式操作
Jul 17 #Javascript
在vue中对数组值变化的监听与重新响应渲染操作
Jul 17 #Javascript
Vue项目中数据的深度监听或对象属性的监听实例
Jul 17 #Javascript
解决vue无法侦听数组及对象属性的变化问题
Jul 17 #Javascript
使用element-ui +Vue 解决 table 里包含表单验证的问题
Jul 17 #Javascript
You might like
php中根据变量的类型 选择echo或dump
2012/07/05 PHP
33道php常见面试题及答案
2015/07/06 PHP
PHP创建word文档的方法(平台无关)
2016/03/29 PHP
PHP内部实现打乱字符串顺序函数str_shuffle的方法
2019/02/14 PHP
IE和Firefox在JavaScript应用中的兼容性探讨
2008/04/01 Javascript
javascript 读取图片文件的大小
2009/06/25 Javascript
JavaScript怎么判断图片是否加载完成以便获取其尺寸
2014/05/08 Javascript
AngularJS实现表单验证
2015/01/28 Javascript
jQuery控制网页打印指定区域的方法
2015/04/07 Javascript
Javascript中For In语句用法实例
2015/05/14 Javascript
基于jQuery实现自动轮播旋转木马特效
2015/11/02 Javascript
Js调用Java方法并互相传参的简单实例
2016/08/11 Javascript
JQuery PHP图片在线裁剪实例
2020/07/27 Javascript
Node.js批量给图片加水印的方法
2016/11/15 Javascript
webpack独立打包和缓存处理详解
2017/04/03 Javascript
详解webpack和webpack-simple中如何引入css文件
2017/06/28 Javascript
Nodejs Express 通过log4js写日志到Logstash(ELK)
2018/08/30 NodeJs
详解Ubuntu安装angular-cli遇到的坑
2018/09/08 Javascript
python创建和使用字典实例详解
2013/11/01 Python
python实现将元祖转换成数组的方法
2015/05/04 Python
Python通过OpenCV的findContours获取轮廓并切割实例
2018/01/05 Python
python 实现将txt文件多行合并为一行并将中间的空格去掉方法
2018/12/20 Python
Python实现打砖块小游戏代码实例
2019/05/18 Python
HTML5添加禁止缩放功能
2017/11/03 HTML / CSS
美国第二大连锁书店:Books-A-Million
2017/12/28 全球购物
MAC彩妆英国官网:M·A·C UK
2018/05/30 全球购物
比较基础的php面试题及答案-填空题
2014/04/26 面试题
c++工程师面试问题
2013/08/04 面试题
SQL Server 2000数据库的文件有哪些,分别进行描述
2013/03/30 面试题
护士实习生自我鉴定范文
2013/12/10 职场文书
服务标兵事迹材料
2014/05/04 职场文书
环保标语口号
2014/06/13 职场文书
2014大学生批评与自我批评思想汇报
2014/09/21 职场文书
2015年度高中教师工作总结
2015/05/26 职场文书
为什么中国式养孩子很累?
2019/08/07 职场文书
十大最帅动漫男主 碓冰拓海上榜,第一是《灌篮高手》男主角
2022/03/18 日漫