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对象(字符串动态创建dom)
May 10 Javascript
使用JS进行目录上传(相当于批量上传)
Dec 05 Javascript
jQuery中:disabled选择器用法实例
Jan 04 Javascript
浅谈js 闭包引起的内存泄露问题
Jun 22 Javascript
JavaScript简单判断复选框是否选中及取出值的方法
Aug 13 Javascript
js实现向右横向滑出的二级菜单效果
Aug 27 Javascript
JavaScript图像延迟加载库Echo.js
Apr 05 Javascript
基于jQuery对象和DOM对象和字符串之间的转化实例
Aug 08 jQuery
Node.JS在命令行中检查Chrome浏览器是否安装并打开指定网址
May 21 Javascript
Vue过渡效果之CSS过渡详解(结合transition,animation,animate.css)
Feb 05 Javascript
微信小程序实现首页弹出广告
Dec 03 Javascript
vue 在单页面应用里使用二级套嵌路由
Dec 19 Vue.js
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
WINDOWS 2000下使用ISAPI方式安装PHP
2006/09/05 PHP
简化php模板页面中分页代码的解析
2009/02/06 PHP
php数组编码转换示例详解
2014/03/11 PHP
php一维二维数组键排序方法实例总结
2014/11/13 PHP
php自动载入类用法实例分析
2016/06/24 PHP
PHP构造函数与析构函数用法示例
2016/09/28 PHP
PHP抽象类和接口用法实例详解
2019/07/20 PHP
php源码的使用方法讲解
2019/09/26 PHP
javascript 当前日期加(天、周、月、年)
2009/08/09 Javascript
JS实现匀速运动的代码实例
2013/11/29 Javascript
node.js中的fs.closeSync方法使用说明
2014/12/17 Javascript
javascript控制层显示或隐藏的方法
2015/07/22 Javascript
基于jQuery+PHP+Mysql实现在线拍照和在线浏览照片
2015/09/06 Javascript
BootStrap中按钮点击后被禁用按钮的最佳实现方法
2016/09/23 Javascript
vue.js中Vue-router 2.0基础实践教程
2017/05/08 Javascript
vue cli构建的项目中请求代理与项目打包问题
2018/02/26 Javascript
Vue中&quot;This dependency was not found&quot;问题的解决方法
2018/06/19 Javascript
vue如何解决循环引用组件报错的问题
2018/09/22 Javascript
vue-router实现嵌套路由的讲解
2019/01/19 Javascript
JS 实现发送短信验证码的“59秒后重新发送验证短信”功能
2019/08/23 Javascript
[01:06:07]2014 DOTA2国际邀请赛中国区预选赛5.21 DT VS CIS
2014/05/22 DOTA
Python常用算法学习基础教程
2017/04/13 Python
python+selenium实现简历自动刷新的示例代码
2019/05/20 Python
python批量爬取下载抖音视频
2019/06/17 Python
python join方法使用详解
2019/07/30 Python
GANT葡萄牙官方商店:拥有美国运动服传统的生活方式品牌
2018/10/18 全球购物
英国景点门票网站:attractiontix
2019/08/27 全球购物
美国床垫连锁店:Mattress Firm
2021/02/13 全球购物
建筑设计专业求职自我评价
2014/03/02 职场文书
《花木兰》教学反思
2014/04/09 职场文书
小学生安全演讲稿
2014/04/25 职场文书
金融事务专业求职信
2014/04/25 职场文书
分公司任命书
2014/06/06 职场文书
七一党日活动总结
2014/07/08 职场文书
小学教师师德师风自我评价
2015/03/04 职场文书
趣味运动会赞词
2015/07/22 职场文书