element 跨页选中,回显el-table选中数据

先配置row-key="id"和reserve-selection="true"属性,保证在数据更新之后保留之前选中的数据
javascript 复制代码
 <el-table
        ref="multipleTable"
        :data="tableData"
        style="width: 100%"
        @selection-change="handleSelectionChange"
        max-height="500"
        row-key="id"
      >
        <el-table-column :reserve-selection="true" type="selection" width="55"> 
        </el-table-column>
 </el-table>
下面这个方法用于回显,确保表格上有勾选样式
javascript 复制代码
toggleSelection(rows) {
      if (rows) {
        setTimeout(() => {
          this.tableData.forEach((item) => {
            rows.forEach((row) => {
              if (item.id == row.parkingId) {
// 如果 item 尚未被选中,则将其选中。如果 item 已经被选中,则代码不会执行任何操作,
                const isSelected = this.$refs.multipleTable.selection.some(
                  (x) => x.id === item.id
                );
                if (!isSelected) {
                  this.$refs.multipleTable.toggleRowSelection(item);
                }
              }
            });
          });
        });
      } else {
        this.$refs.multipleTable.clearSelection();
      }
    },

// rows为选中行数据
this.toggleSelection(rows);

以下为AI解释

这段代码定义了一个名为 `toggleSelection` 的方法,用于在 Element UI 的 `el-table` 组件中根据传入的 `rows` 参数来选中或取消选中特定的行。下面是对代码的详细解释:
1. `toggleSelection(rows) { ... }`
  • 定义了一个方法 `toggleSelection`,它接受一个参数 `rows`。`rows` 应该是一个包含行数据的数组。
2. `if (rows) { ... } else { ... }`
  • 这个条件语句检查 `rows` 是否存在。如果 `rows` 参数被提供(即不是 `null` 或 `undefined`),则执行 `if` 分支中的代码;否则,执行 `else` 分支中的代码。
3. `setTimeout(() => { ... }, 0);`
  • 使用 `setTimeout` 创建一个异步回调,该回调在当前调用栈结束后立即执行。这通常用于确保某些 DOM 更新完成后再执行代码。
4. `this.tableData.forEach((item) => { ... });`
  • 遍历 `tableData` 数组中的每一项(这里命名为 `item`)。
5. `rows.forEach((row) => { ... });`
  • 对于每个 `item`,再遍历传入的 `rows` 数组中的每一项(这里命名为 `row`)。
6. `if (item.id == row.parkingId) { ... }`
  • 检查当前 `item` 的 `id` 是否等于 `row` 的 `parkingId`。如果相等,说明 `item` 是需要被选中的行。
7. `const isSelected = this.$refs.multipleTable.selection.some((x) => x.id === item.id);`
  • 检查 `item` 是否已经在 `el-table` 的当前选中行列表中。
8. `if (!isSelected) { this.$refs.multipleTable.toggleRowSelection(item); }`
  • 如果 `item` 尚未被选中,则调用 `toggleRowSelection` 方法将其选中。
9. `else { this.$refs.multipleTable.clearSelection(); }`
  • 如果 `rows` 参数没有被提供,则调用 `clearSelection` 方法来取消选中所有行。
总结来说,这个方法用于根据传入的行数据数组 `rows` 来更新 `el-table` 组件的选中行。如果传入了 `rows`,则遍历 `tableData` 并根据 `rows` 中的 `parkingId` 来选中对应的行。如果没有传入 `rows`,则取消所有行的选中状态。通过这种方式,可以实现跨页保持选中状态的功能。
相关推荐
爱分享的程序员14 分钟前
前端面试专栏-算法篇:18. 查找算法(二分查找、哈希查找)
前端·javascript·node.js
翻滚吧键盘19 分钟前
vue 条件渲染(v-if v-else-if v-else v-show)
前端·javascript·vue.js
vim怎么退出21 分钟前
万字长文带你了解微前端架构
前端·微服务·前端框架
你这个年龄怎么睡得着的21 分钟前
为什么 JavaScript 中 'str' 不是对象,却能调用方法?
前端·javascript·面试
Java水解23 分钟前
前端常用单位em/px/rem/vh/vm到底有什么区别?
前端
CAD老兵26 分钟前
Vite 如何借助 esbuild 实现极速 Dev Server 体验,并支持无 source map 的源码调试
前端
南屿im27 分钟前
JavaScript 手写实现防抖与节流:优化高频事件处理的利器
前端·javascript
Spider_Man27 分钟前
从零开始构建React天气应用:API集成与UI设计全指南 🌤️
前端·react.js
浩浩测试一下43 分钟前
渗透信息收集- Web应用漏洞与指纹信息收集以及情报收集
android·前端·安全·web安全·网络安全·安全架构
西陵1 小时前
Nx带来极致的前端开发体验——借助CDD&TDD开发提效
前端·javascript·架构