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)
}
相关推荐
谷无姜6 小时前
JS必须过的槛--原型链,看完直接懂了!!
javascript
JohnYan7 小时前
Bun技术评估 - 26 Abort
javascript·后端·bun
小马哥编程7 小时前
【软考架构】案例分析-web应用设计:SSH 和 SSM(Spring + Spring MVC + MyBatis ) 之间的区别,以及使用场景
前端·架构·ssh
用户103113311667 小时前
Vuex学习记录
前端
inBuilder低代码平台7 小时前
Electron应用优化与性能调优策略
javascript·性能优化·electron
前端开发爱好者7 小时前
Electron 淘汰!新的跨端框架来了!性能飙升!
前端·javascript
狮子座的男孩7 小时前
js基础:08、构造函数(共享方法)、原型(prototype)、原型对象、(修改原型)toString方法、垃圾回收
前端·javascript·经验分享·prototype·垃圾回收·构造函数·原型对象
前端开发爱好者7 小时前
Vue 团队成员又搞了个 "新玩具"!
前端·javascript·vue.js
musenh7 小时前
javascript学习
开发语言·javascript·学习
一 乐7 小时前
农产品销售系统|农产品电商|基于SprinBoot+vue的农产品销售系统(源码+数据库+文档)
java·javascript·数据库·vue.js·spring boot·后端·农产品销售系统