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中外部传入控制。以上就是涉及到多选模式下使用单选的主要代码了。

Element UITable 组件默认支持分页功能,如果你想实现在跨页情况下进行多选,可以结合其提供的`selection`属性和自定义事件处理。`selection`属性允许你在表格上设置单选多选模式,你可以通过监听`@selection-change`事件来跟踪用户的选中状态,不论是在哪一页。 以下是实现步骤: 1. 在 Vue 中配置 `element-ui` 的 Table,设置 `selection` 为 `multiple` 或 `row-key` 来保证行级选择(如果你需要基于每个条目的唯一标识符进行多选): ```html <el-table :data="tableData" selection="multiple"> <!-- 表格列 --> </el-table> ``` 2. 在组件内获取和处理选择的数据: ```javascript export default { data() { return { tableData: [], // 假设这是你的数据源 selectedItems: [] // 存储选中的行 }; }, methods: { handleSelectionChange(val) { this.selectedItems = val; // 当用户切换选择时,更新selectedItems } }, watch: { $refs: { handler(newRef, oldRef) { if (newRef && newRef.$el) { newRef.$el.addEventListener('selection-change', this.handleSelectionChange); } else if (oldRef) { oldRef.$el.removeEventListener('selection-change', this.handleSelectionChange); } }, deep: true } } } ``` 3. 如果有分页,你需要额外处理每页的数据同步: ```javascript // 假设你有一个分页器 component,如 el-pagination this.pagination.currentPage.value = 1; // 刷新到第一页 this.getTableData(page => { // 获取当前页数据并更新表格及选择 // 更新selectedItems为你在新数据中的选择 }); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值