elementUI Checkbox 多选框互斥事件

elementUI Checkbox 多选框互斥事件

需求

项目使用的vue2+elementUI,项目的查询接口遇到一个需求:

复制代码
1.多个标签
2.标签数据由后端接口给出;
3.可以多选标签;
4.有两个标签为默认存在的标签:任意标签 和 无标签;
5.这个两个默认标签为互斥标签,且存在这两个默认标签中任意一个标签时,其他标签不可选,如果其他标签已选中,清除选中的其他标签;
6.这两个默认标签未选中时,其他标签可选。

效果(下方截图为连续性操作)

未选中

选中其他标签

选中任意标签,其他标签清空选中

选中无标签,其他标签清空选中

解决代码

html

javascript 复制代码
<template>
	<el-checkbox-group v-model="flag" size="mini" @change="changeValue">
		<el-checkbox label="1" border @change="changeAny">任意标签</el-checkbox>
		<el-checkbox label="0" border @change="changeNone">无标签</el-checkbox>
		<el-checkbox v-for="item in labelList" :key="item.id" :label="item.id" border>
			{{ item.name }}
		</el-checkbox>
	</el-checkbox-group>
</template>

js

javascript 复制代码
<script>
export default {
	data() {
		return {
      		flag: [],
      		labelList: [],
		}
	},
	methods: {
		changeValue() {
			if (this.flag.includes('none')) {
	          this.flag = ['none']
	        } else if (this.flag.includes('any')) {
	          this.flag = ['any']
	        }
		},
		// 任意标签 (任意标签与无标签只能二选一)
	    changeAny(value) {
	      if (value) {
	        this.flag = ['1']
	      }
	    },
	    // 无标签 (任意标签与无标签只能二选一)
	    changeNone(value) {
	      if (value) {
	        this.flag = ['0']
	      }
	    },
	}
}
</script>
相关推荐
老马识途2.019 分钟前
在AI的帮助下理解spring的启动过程
java·前端·spring
徐小夕1 小时前
Loop Engineering 深度解析与实战指南(全网最全)
前端·算法·github
运筹vivo@1 小时前
Python ContextVar 底层机制与内存模型拆解
前端·数据库·python
#麻辣小龙虾#2 小时前
基于vue3.0开发一款【固废与废气运维管理系统】(支持源码)
前端·vue.js·vue3
Cosolar2 小时前
Docsify零构建文档站完全指南:从快速搭建到企业级部署
前端·开源·github
weixin_471383033 小时前
Taro-02-页面路由
前端·taro
星栈独行3 小时前
Makepad 应用如何读文件、调接口、保存数据
前端·程序人生·ui·rust·github
IT_陈寒3 小时前
Vite热更新失效?可能你在用Windows
前端·人工智能·后端
烬羽4 小时前
后端返回的 JSON 字符串,浏览器怎么"看懂"的?——Ajax 全链路拆解
javascript
tedcloud1234 小时前
taste-skill部署教程:打造个性化AI推荐工作流
服务器·前端·人工智能·系统架构·edge