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)
}
相关推荐
掘金0131 分钟前
EmbedPDF Vue 版 完整正文文档 全网首发
前端
OpenTiny社区33 分钟前
操作ArkTS页面跳转及路由相关心得
前端·typescript·web·opentiny
xiaohua0708day33 分钟前
Lodash库
前端·javascript·vue.js
huakoh33 分钟前
Claude Code 从零到上手指南:国产工具链复现80% Agent能力,DeepSeek+LangChain实战
前端
Ankkaya36 分钟前
浏览器插件接入 Google 登录
前端
Asmewill38 分钟前
DeepAgents学习笔记一(构建深度多智能体)
前端
万物皆对象66638 分钟前
切换路由时页面空白问题(vue3)
前端·vue.js·typescript
突然好热39 分钟前
TS 调试技巧
前端·javascript·typescript
h64648564h40 分钟前
Flutter 国际化(i18n)全指南:一键切换中/英/日多语言
前端·javascript·flutter
令人头秃的代码0_040 分钟前
AI时代下,如何做原子代码拆分
前端