后端返回大量数据,且 需要做全选操作,使用虚拟滚动和懒加载都实现不了。无法选择中所有数据,自己做分页,传递所有数据

element-ui的el-table


<el-button :type="buttonTypes.search" @click="AllChange(tableData,1)">
     全部选择
</el-button>

<el-table
     ref="restLeft"
     :data="compontentList"
     style="width: 100%;"
     @selection-change="handleSelectionChange"
>
     <el-table-column type="selection" width="55" align="center">
     </el-table-column>
      ...
</el-table>

分页

<pagination
      :total="tableData.length"
      :page.sync="pageNum"
      :limit.sync="pageSize"
      @pagination="sliceList"
/>

js方法

// 数据分页
    sliceList() {
      let listData = this.tableData.slice(
          (this.pageNum - 1) * this.pageSize,
          this.pageNum * this.pageSize
      );
      this.compontentList = [];
      this.$set(this, "compontentList", listData);
      this.$nextTick(()=>{
        if(this.isAll){
          if (!this.selectingAll) {
            this.selectingAll = true;
            this.compontentList.forEach((row) => {
              this.$refs.restLeft.toggleRowSelection(row);
            });
            this.selectingAll = false;
          }
          this.AllChange(this.tableData,2)
        }
      })
    },

//全选按钮
AllChange(arrData,v) {
      if(v===1){
        if (!this.selectingAll) {
          this.selectingAll = true;
          this.compontentList.forEach((row) => {
            this.$refs.restLeft.toggleRowSelection(row);
          });
          this.selectingAll = false;
        }
        this.isAll ? this.pitchData = [] : this.pitchData = arrData;
        this.isAll ?  this.isAll = false : this.isAll = true;
      }else{
        this.pitchData = arrData;
        this.isAll = true;
      }
    },

// table选中
    handleSelectionChange(arrData) {
      this.pitchData = arrData;
    },

排产计划

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

SKMA

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值