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 相关文章推荐
JQuery slideshow的一个小问题(如何发现及解决过程)
Feb 06 Javascript
JS远程获取网页源代码实例
Sep 05 Javascript
js获取当前月的第一天和最后一天的小例子
Nov 18 Javascript
Javascript Objects详解
Sep 04 Javascript
node.js中的fs.appendFileSync方法使用说明
Dec 17 Javascript
jquery对所有input type=text的控件赋值实现方法
Dec 02 Javascript
Vue的路由动态重定向和导航守卫实例
Mar 17 Javascript
vue中的数据绑定原理的实现
Jul 02 Javascript
vue router 跳转时打开新页面的示例方法
Jul 28 Javascript
关于JS解构的5种有趣用法
Sep 05 Javascript
vue.js实现左边导航切换右边内容
Oct 21 Javascript
vue指令v-html使用过滤器filters功能实例
Oct 25 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计数器的实现代码
2013/06/08 PHP
php记录代码执行时间(实现代码)
2013/07/05 PHP
jsTree树控件(基于jQuery, 超强悍)[推荐]
2009/09/01 Javascript
理解Javascript_08_函数对象
2010/10/15 Javascript
Javascript面向对象编程
2012/03/18 Javascript
圣诞节Merry Christmas给博客添加浪漫的下雪效果基于jquery实现
2012/12/27 Javascript
JS获取当前日期和时间的简单实例
2013/11/19 Javascript
JS不间断向上滚动效果代码
2013/12/25 Javascript
javascript移出节点removeChild()使用介绍
2014/04/03 Javascript
setInterval计时器不准的问题解决方法
2014/05/08 Javascript
jQuery实现新消息闪烁标题提示的方法
2015/03/11 Javascript
JavaScript给按钮绑定点击事件(onclick)的方法
2015/04/07 Javascript
在JavaScript的正则表达式中使用exec()方法
2015/06/16 Javascript
详解JavaScript中jQuery和Ajax以及JSONP的联合使用
2015/08/13 Javascript
JavaScript位移运算符(无符号) &gt;&gt;&gt; 三个大于号 的使用方法详解
2016/03/31 Javascript
Vue实现的父组件向子组件传值功能示例
2019/01/19 Javascript
微信小程序页面渲染实现方法
2019/11/06 Javascript
python模拟登陆Tom邮箱示例分享
2014/01/13 Python
python清除字符串里非数字字符的方法
2015/07/02 Python
Python模拟登录验证码(代码简单)
2016/02/06 Python
Python 常用的安装Module方式汇总
2017/05/06 Python
在cmd命令行里进入和退出Python程序的方法
2018/05/12 Python
Python 用turtle实现用正方形画圆的例子
2019/11/21 Python
使用python实现学生信息管理系统
2021/02/25 Python
你正在寻找的CSS3 动画技术
2011/07/27 HTML / CSS
canvas之万花筒效果的简单实现(推荐)
2016/08/16 HTML / CSS
STRATHBERRY苏贝瑞包包官网:西班牙高级工匠手工打造
2020/11/10 全球购物
在网络中有两台主机A和B,并通过路由器和其他交换设备连接起来,已经确认物理连接正确无误,怎么来测试这两台机器是否连通?如果不通,怎么来判断故障点?怎么排
2014/01/13 面试题
电台编导求职信
2014/05/06 职场文书
服务标语口号
2014/07/01 职场文书
幼儿园端午节活动方案
2014/08/25 职场文书
工作散漫检讨书
2014/09/16 职场文书
监察局领导班子四风问题整改措施思想汇报
2014/10/05 职场文书
校运会加油稿大全
2015/07/22 职场文书
Element-ui Layout布局(Row和Col组件)的实现
2021/12/06 Vue.js
Python通用验证码识别OCR库ddddocr的安装使用教程
2022/07/07 Python