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)
}
相关推荐
LeeAt4 分钟前
npm:详细解释前端项目开发前奏!!
前端·node.js·html
山有木兮木有枝_6 分钟前
JavaScript对象深度解析:从创建到类型判断 (上)
前端
crary,记忆13 分钟前
MFE(微前端) Module Federation:Webpack.config.js文件中每个属性的含义解释
前端·学习·webpack
清风~徐~来16 分钟前
【Qt】控件 QWidget
前端·数据库·qt
前端小白从0开始16 分钟前
关于前端常用的部分公共方法(二)
前端·vue.js·正则表达式·typescript·html5·公共方法
真的很上进23 分钟前
2025最全TS手写题之partial/Omit/Pick/Exclude/Readonly/Required
java·前端·vue.js·python·算法·react·html5
用户69452955217026 分钟前
国内开源版“Manus”——AiPy实测:让你的工作生活走上“智动”化
前端·后端
帅夫帅夫28 分钟前
一文手撕call、apply、bind
前端·javascript·面试
J船长31 分钟前
APK战争 diffoscope
前端