el-table支持多页的多选

在使用el-table自带多选时,会发现切页之后上一页的选择无法保持,但是在某些业务场景中,需要支持多页多选,记住之前的选择

javascript 复制代码
 <el-table
   :data="standardDatasets"
   border
   @select="handleSelectionChange"
   @select-all="handleSelectAll">
   <el-table-column type="selection" width="55" />
</el-table>
javascript 复制代码
const selectedDataset = ref([])
// 如果存在就删除 如果没有存在就加入
function handleSelectionChange(rows, row) {
  if (selectedDataset.value.find(item => item == row.id)) {
    //下面这个filter方法就是删除的方法
    selectedDataset.value = selectedDataset.value.filter(item => item != row.id)
  } else {
    selectedDataset.value.push(row.id)
  }
}
//处理全选问题
function handleSelectAll(rows) {
  if (rows.length) {
    rows.forEach(row => {
      if (!selectedDataset.value.find(item => item == row.id)) {
        selectedDataset.value.push(row.id)
      }
    })
  } else {
    standardDatasets.forEach(row => {
      selectedDataset.value = selectedDataset.value.filter(
        item => item != row.id
      )
    })
  }
  // console.log(selectedDataset.value, rows, taskList)
}
相关推荐
d***93518 小时前
springboot3.X 无法解析parameter参数问题
android·前端·后端
n***840719 小时前
十七:Spring Boot依赖 (2)-- spring-boot-starter-web 依赖详解
前端·spring boot·后端
likuolei1 天前
XSL-FO 软件
java·开发语言·前端·数据库
正一品程序员1 天前
vue项目引入GoogleMap API进行网格区域圈选
前端·javascript·vue.js
j***89461 天前
spring-boot-starter和spring-boot-starter-web的关联
前端
star_11121 天前
Jenkins+nginx部署前端vue项目
前端·vue.js·jenkins
im_AMBER1 天前
Canvas架构手记 05 鼠标事件监听 | 原生事件封装 | ctx 结构化对象
前端·笔记·学习·架构
JIngJaneIL1 天前
农产品电商|基于SprinBoot+vue的农产品电商系统(源码+数据库+文档)
java·前端·数据库·vue.js·spring boot·毕设·农产品电商系统
Tongfront1 天前
前端通用submit方法
开发语言·前端·javascript·react
c***72741 天前
SpringBoot + vue 管理系统
vue.js·spring boot·后端