实现el-table两列多选框且不可同时勾选

1、效果图如下,功能:必修和选修不可同时勾选

2、代码如下

bash 复制代码
<template>
      <el-table :data="addTableData" style="width: 100%">
        <el-table-column label="必修" width="55px" align="center">
          <template slot-scope="scope">
            <el-checkbox v-model="checked1" :label="scope.row.id" @change="checkboxChange($event,scope.row.id,'checked2')"><span></span></el-checkbox>
          </template>
        </el-table-column>
        <el-table-column label="选修" width="55px" align="center">
          <template slot-scope="scope">
            <el-checkbox v-model="checked2" :label="scope.row.id" @change="checkboxChange($event,scope.row.id,'checked1')"><span></span></el-checkbox>
          </template>
        </el-table-column>
        <el-table-column prop="id" label="编号" width="60px" align="center"></el-table-column>
        <el-table-column prop="name" label="名称" align="center"></el-table-column>
        <el-table-column prop="name" label="学时" width="60px"  align="center"></el-table-column>
      </el-table>
</template>


  export default {
    data() {
      return {
        checked1:[],//必修已选
        checked2:[],//选修已选
      }
    }

    methods: {
      checkboxChange(val,id,type) {
        if(val === true) {
          this[type] = this[type].filter(function(item) {
            return item !== id;  // 过滤出值不为2的元素
          });
        }
      },
    },
  }
相关推荐
南半球与北海道#18 小时前
el-table合并单元格
javascript·vue.js·elementui·表格合并
吃饭了吗1 天前
elementplus组件文本框设置前缀
前端·vue.js·elementui
进阶的小木桩6 天前
Vue 3 + Elementui + TypeScript 实现左侧菜单定位右侧内容
vue.js·elementui·typescript
北辰浮光9 天前
[Element-plus]动态设置组件的语言
javascript·vue.js·elementui
胡斌附体9 天前
elementui cascader 远程加载请求使用 选择单项等
前端·javascript·elementui·cascader·可独立选中单节点
小离a_a11 天前
el-tree方法的整理
前端·vue.js·elementui
code_txy12 天前
element plus table 表格操作列根据按钮数量自适应宽度
elementui
阿奇__12 天前
深度修改elementUI样式思路
前端·vue.js·elementui
什么什么什么?15 天前
el-table高度自适应vue页面指令
前端·javascript·elementui
海天胜景16 天前
vue3 el-table 去除小数 并使用千分号
javascript·vue.js·elementui