Vue3 -- 设置分页,切换分页之后选项仍能保留 & 控制多个表格的选中不会互相影响

在 Vue 3 中实现分页功能,并确保在切换分页时选中的选项能够保留,同时控制多个表格之间的选中状态不互相影响,可以按照以下步骤进行:

1. 数据结构设计

为每个表格维护独立的选中项和分页状态。可以使用一个对象来存储每个表格的选中项和分页信息:

javascript 复制代码
data() {
  return {
    appDeployForm: {
      detail: [
        { 
          hostForm: [], 
          selectedHosts: [], 
          currentPage: 1, 
          pageSize: 10, 
          total: 0 
        }, // 第一个表格
        { 
          hostForm: [], 
          selectedHosts: [], 
          currentPage: 1, 
          pageSize: 10, 
          total: 0 
        }  // 第二个表格
      ]
    }
  };
}

2. 表格渲染

使用 v-for 渲染多个表格,并在每个表格中使用 el-table 组件。确保每个表格都能独立管理自己的选中项和分页状态:

html 复制代码
<el-row v-for="(item, index) in appDeployForm.detail" :key="index">
  <el-col :span="24">
    <el-form-item :label="$t('labels.host')">
      <el-table
        :data="item.hostForm"
        border
        style="width:90%"
        highlight-current-row
        @selection-change="handleSelectionChange(item, $event)"
      >
        <el-table-column type="selection" width="55"></el-table-column>
        <el-table-column prop="name" :label="$t('columns.hostName')" align="left" min-width="5"></el-table-column>
        <el-table-column prop="operation" :label="$t('columns.operation')" align="center" min-width="5">
          <template #default="scope">
            <a style="color:#1890ff;cursor:pointer" @click="deleteHost(scope.$index, scope.row, index)">删除</a>
          </template>
        </el-table-column>
      </el-table>
    </el-form-item>
    <el-pagination
      @current-change="handlePageChange(item, $event)"
      :current-page="item.currentPage"
      :page-size="item.pageSize"
      :total="item.total"
    ></el-pagination>
  </el-col>
</el-row>

3. 处理选中项

在表格的 @selection-change 事件中,更新对应表格的选中项:

javascript 复制代码
methods: {
  handleSelectionChange(item, selectedRows) {
    item.selectedHosts = selectedRows;
  },
  deleteHost(index, row, tableIndex) {
    // 删除逻辑
  },
  handlePageChange(item, newPage) {
    item.currentPage = newPage;
    // 这里可以添加逻辑来更新表格数据,例如重新请求数据
  }
}

4. 保持选中项

在切换分页时,确保选中项能够保留。由于每个表格的选中项是独立的,切换分页不会影响其他表格的选中状态。

5. 示例代码

以下是完整的示例代码,展示了如何实现上述功能:

html 复制代码
<template>
  <el-row v-for="(item, index) in appDeployForm.detail" :key="index">
    <el-col :span="24">
      <el-form-item :label="$t('labels.host')">
        <el-table
          :data="item.hostForm"
          border
          style="width:90%"
          highlight-current-row
          @selection-change="handleSelectionChange(item, $event)"
        >
          <el-table-column type="selection" width="55"></el-table-column>
          <el-table-column prop="name" :label="$t('columns.hostName')" align="left" min-width="5"></el-table-column>
          <el-table-column prop="operation" :label="$t('columns.operation')" align="center" min-width="5">
            <template #default="scope">
              <a style="color:#1890ff;cursor:pointer" @click="deleteHost(scope.$index, scope.row, index)">删除</a>
            </template>
          </el-table-column>
        </el-table>
      </el-form-item>
      <el-pagination
        @current-change="handlePageChange(item, $event)"
        :current-page="item.currentPage"
        :page-size="item.pageSize"
        :total="item.total"
      ></el-pagination>
    </el-col>
  </el-row>
</template>

<script>
export default {
  data() {
    return {
      appDeployForm: {
        detail: [
          { hostForm: [], selectedHosts: [], currentPage: 1, pageSize: 10, total: 0 },
          { hostForm: [], selectedHosts: [], currentPage: 1, pageSize: 10, total: 0 }
        ]
      }
    };
  },
  methods: {
    handleSelectionChange(item, selectedRows) {
      item.selectedHosts = selectedRows;
    },
    deleteHost(index, row, tableIndex) {
      // 删除逻辑
    },
    handlePageChange(item, newPage) {
      item.currentPage = newPage;
      // 更新表格数据逻辑
    }
  }
};
</script>

总结

通过以上步骤,可以在 Vue 3 应用中实现分页功能,并确保在切换分页时选中的项能够保留,同时控制多个表格之间的选中状态不互相影响。这种设计提升了用户体验,使得操作更加直观和灵活。

相关推荐
PleaSure乐事17 分钟前
Ant-Dseign-Pro如何去国际化及删除oneapi.json后出现程序直接结束问题的解决方案
前端·javascript·react.js·前端框架·json·oneapi·antdesignpro
榴莲千丞36 分钟前
第七章利用CSS和多媒体美化页面
前端·css·1024程序员节
奶糖 肥晨1 小时前
vue的路由的两种模式 hash与history 详细讲解
前端·vue.js·哈希算法
奶糖 肥晨1 小时前
react基础之reactHooks
前端·javascript·react.js
放逐者-保持本心,方可放逐1 小时前
vue3-ref 和 reactive
前端·javascript·vue.js
星河路漫漫1 小时前
ES6面试题:(第二天)
开发语言·前端·javascript
喝旺仔la2 小时前
Django+Vue全栈开发旅游网项目景点详情
前端·javascript·vue.js
snakeshe10102 小时前
深入理解 Web Workers:提升 Web 应用性能的利器
前端
每天都要喝奶茶2 小时前
vue3uniapp实现自定义拱形底部导航栏,解决首次闪烁问题
前端·vue.js·uni-app
Southern Wind2 小时前
H5页面在线预览pdf
javascript·pdf