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)
}
相关推荐
程序员小易9 分钟前
前端轮子(2)--diy响应数据
前端·javascript·浏览器
前天的五花肉9 分钟前
D3.js研发Biplot(代谢)图
前端·javascript·css
董世昌4112 分钟前
JavaScript 中 undefined 和 not defined 的区别
java·服务器·javascript
oh,huoyuyan15 分钟前
【实用技巧】火语言RPA:界面『日期时间』控件,实现网页日期自动填写
前端·javascript·rpa
程序员小寒15 分钟前
前端性能优化之Webpack篇
前端·webpack·性能优化
谢尔登16 分钟前
React的Fiber架构
前端·react.js·架构
我是华为OD~HR~栗栗呀19 分钟前
(华为od)21届-Python面经
java·前端·c++·python·华为od·华为·面试
武昌库里写JAVA21 分钟前
java设计模式 - 工厂方法模式
vue.js·spring boot·sql·layui·课程设计
刘一说30 分钟前
ES6+核心特性全面浅析
java·前端·es6
i_am_a_div_日积月累_34 分钟前
el-tree半选回显问题;el-tree获取半选节点id
javascript·vue.js·elementui