el-table 默认数据选中优化版本

直接看代码

javascript 复制代码
<template>
  <div>
    <el-table
      ref="multipleTable"
      :data="tableData"
      tooltip-effect="dark"
      style="width: 100%;height:500px"
      @select="handleSelectChange"
      @select-all="handleSelectAllChange"
      row-key="id"
    >
    <!-- reserve-selection 可以不要 但是就没有分页半选状态 没有的话 下handleSelectAllChange部分代码可以不要-->
      <el-table-column
        type="selection"
        width="55"
        reserve-selection
      />
      <el-table-column
        label="日期"
        width="120"
        prop="date"
      />
      <el-table-column
        prop="name"
        label="姓名"
        width="120"
      />
    </el-table>
    <el-pagination
      background
      :current-page.sync="currentPage"
      layout="prev, pager, next"
      :total="1000"
      @current-change="currentChange"
    />
  </div>
</template>

<script>
export default {
  data () {
    return {
      currentPage: 1,
      crossPageMap: new Map(),
      pageSize: 10,
      totalData: Array.from({ length: 1000 }, (_, index) => {
        return {
          date: '2016-05-03',
          id: index,
          name: '王小虎' + index
        }
      })
    }
  },
  computed: {
    tableData () {
      const { currentPage, totalData, pageSize } = this
      return totalData.slice((currentPage - 1) * pageSize, currentPage * pageSize)
    },
   
    
  },
  
  methods: {
    currentChange (page) {
      this.currentPage = page
      this.search()

    },
    handleSelectChange (val, row) {
      const checked = this.crossPageMap.has(row.id)
      if (checked) {
        this.crossPageMap.delete(row.id)
      } else {
        this.crossPageMap.set(row.id, row)
      }
    },
    handleSelectAllChange (val) {
      this.tableData.forEach(row => {
        const isChecked = this.crossPageMap.has(row.id)
        if (val.length === 0) {
          // 取消全选 只有选中的需要改变状态
          if (isChecked) this.crossPageMap.delete(row.id)
        } else {
          // 全选 
          //  因为有reserve-selection 所以会返回其他页的数据 如果val里面没有当前页的数据 就删除 如果没有reserve-selection 则不需要这行循环的代码
          // reserve-selection 可以让分页的全选按钮保留半选状态
          if(val.findIndex(ele => ele.id == row.id) == -1){
            this.crossPageMap.delete(row.id)
          }
          //如果没有选中就添加
          if (!isChecked) this.crossPageMap.set(row.id,row)
        }
      })
    },
    search(){
      this.tableData.forEach(row => {
        const checked = this.crossPageMap.has(row.id)
        if (checked) this.$refs.multipleTable.toggleRowSelection(row, true)
      })
      // this.crossPageMap 请注意,无法响应式 计算属性也不行 有黑科技可以在计算属性里面用一个其他的属性收集依赖 每次选中项变化时修改这个属性,
      // 就可以进行触发 如果需要页面展示选中的数据 可以研究一下发个链接参考参考
      console.log(Array.from(this.crossPageMap.values()));
    }
  },
  mounted(){
    this.$nextTick(()=>{
      this.$refs.multipleTable.clearSelection()
      // 默认选中项目
      let defaultChecked = [{ id: 13},{id: 3}]
      defaultChecked.forEach(ele => {
        this.crossPageMap.set(ele.id, ele)
      })
      this.search()
    })
    
  }
}
</script>

注意reserve-selection用法

相关代码借鉴掘金 链接找不到了

相关推荐
方也_arkling6 小时前
别名路径联想提示。@/统一文件路径的配置
前端·javascript
毕设源码-朱学姐6 小时前
【开题答辩全过程】以 基于web教师继续教育系统的设计与实现为例,包含答辩的问题和答案
前端
qq_177767376 小时前
React Native鸿蒙跨平台剧集管理应用实现,包含主应用组件、剧集列表、分类筛选、搜索排序等功能模块
javascript·react native·react.js·交互·harmonyos
qq_177767376 小时前
React Native鸿蒙跨平台自定义复选框组件,通过样式数组实现选中/未选中状态的样式切换,使用链式调用替代样式数组,实现状态驱动的样式变化
javascript·react native·react.js·架构·ecmascript·harmonyos·媒体
web打印社区6 小时前
web-print-pdf:突破浏览器限制,实现专业级Web静默打印
前端·javascript·vue.js·electron·html
RFCEO7 小时前
前端编程 课程十三、:CSS核心基础1:CSS选择器
前端·css·css基础选择器详细教程·css类选择器使用方法·css类选择器命名规范·css后代选择器·精准选中嵌套元素
烬头88217 小时前
React Native鸿蒙跨平台采用了函数式组件的形式,通过 props 接收分类数据,使用 TouchableOpacity实现了点击交互效果
javascript·react native·react.js·ecmascript·交互·harmonyos
Amumu121387 小时前
Vuex介绍
前端·javascript·vue.js
We་ct7 小时前
LeetCode 54. 螺旋矩阵:两种解法吃透顺时针遍历逻辑
前端·算法·leetcode·矩阵·typescript
2601_949809597 小时前
flutter_for_openharmony家庭相册app实战+相册详情实现
javascript·flutter·ajax