element-ui之el-table利用多选实现单选效果

 (demo中版本element-ui版本为: "^2.15.12")

在element-ui中是为我们准备好了可直接使用的单选与多选属性的。但是单选与多选的形式不一样,在某些情况下我们可能想让它们的选择方式尽量统一,于是我想能不能把利用多选属性实现多选,并用一个变量来控制表格是多选还是单选。

要实现单选有两步:一、隐藏多选选择框。二、每次选择只能选择一个。

一、隐藏多选选择框

第一个最好实现,打开f12找到相应元素,隐藏即可。css代码如下:

给<el-table>添加上no-multiple这个class即可隐藏多选。

.no-multiple {
  // 隐藏多选
  ::v-deep .el-table__header-wrapper .el-checkbox {
    display: none;
  }
}

二、实现每次选择只能选择一个

        template部分:

(给el-table添加selection-change和select方法)

<el-table
v-loading="isLoading"
ref="multipleTable"
height="340px"
:data="tableData"
:class="{ 'no-multiple': !isMultiple }"
@selection-change="handleSelectionChange"
@select="selectTable"
>
</el-table>

js部分:

handleSelectionChange(val) {
      // 通过配置判断是否可多选
      if (this.isMultiple) {
        this.multipleSelection = val
      } else {
        if (val.length > 1) {
          this.$refs.multipleTable.clearSelection()
          this.$refs.multipleTable.toggleRowSelection(val.pop())
        }
      }
    },
    selectTable(selection, row) {
      // 单选时
      if (!this.isMultiple) {
        this.multipleSelection = [row]
      }
    }

我们在data中定义了一个变量isMultiple来决定是否单选,也可以放在props中外部传入控制。以上就是涉及到多选模式下使用单选的主要代码了。

  • 4
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以通过以下步骤实现elementui的表格多选单选: 1. 隐藏多选框:在样式中添加以下代码:`.el-table__header .el-checkbox { display: none; }` 2. 监听selection-change事件:在el-table标签中添加`@selection-change="handleSelectionChange"`,并在methods中添加`handleSelectionChange`方法。 3. 在handleSelectionChange方法中判断选中的行数,如果大于1,则清除所有选中项,只选中最后一个选中的项;否则,将选中项赋值给tableSelect。 4. 在table中添加`:row-class-name="tableRowClassName"`,并在methods中添加`tableRowClassName`方法,用于判断当前行是否被选中,如果被选中,则添加`row-selected`类名。 5. 在样式中添加以下代码:`.row-selected .el-checkbox { display: none; }`,用于隐藏多选框。 代码如下: ```html <template> <el-table :data="tableData" :row-class-name="tableRowClassName" @selection-change="handleSelectionChange"> <el-table-column type="selection" width="55"></el-table-column> <el-table-column label="角色名称" min-width="120" prop="name"></el-table-column> <el-table-column prop="num" label="成员数量" min-width="120"></el-table-column> </el-table> </template> <script> export default { data() { return { tableData: [], tableSelect: [] } }, methods: { handleSelectionChange(val) { if (val.length > 1) { this.$refs.multipleTable.clearSelection(); this.$refs.multipleTable.toggleRowSelection(val.pop()); } else { this.tableSelect = val; } }, tableRowClassName({ row }) { if (this.tableSelect.indexOf(row) !== -1) { return 'row-selected'; } return ''; } } } </script> <style scoped> .el-table__header .el-checkbox { display: none; } .row-selected .el-checkbox { display: none; } </style> ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值