当前位置:首页 > VUE

vue实现表格页面分页

2026-02-21 07:32:27VUE

实现表格分页的基本思路

在Vue中实现表格分页通常需要结合前端分页逻辑和后端API支持。前端分页适用于数据量较小的情况,直接截取数组展示;后端分页则需要通过API接口按需请求数据。

前端分页实现方法

创建计算属性处理分页数据:

computed: {
  paginatedData() {
    const start = (this.currentPage - 1) * this.pageSize
    const end = start + this.pageSize
    return this.tableData.slice(start, end)
  }
}

配置分页参数:

data() {
  return {
    currentPage: 1,
    pageSize: 10,
    tableData: [] // 原始数据
  }
}

模板中使用分页控件:

<el-table :data="paginatedData">
  <!-- 表格列定义 -->
</el-table>

<el-pagination
  @size-change="handleSizeChange"
  @current-change="handleCurrentChange"
  :current-page="currentPage"
  :page-sizes="[10, 20, 50, 100]"
  :page-size="pageSize"
  layout="total, sizes, prev, pager, next, jumper"
  :total="tableData.length">
</el-pagination>

后端分页实现方法

请求数据时携带分页参数:

vue实现表格页面分页

methods: {
  fetchData() {
    const params = {
      page: this.currentPage,
      size: this.pageSize
    }
    api.getTableData(params).then(res => {
      this.tableData = res.data.list
      this.total = res.data.total
    })
  }
}

分页事件处理方法:

methods: {
  handleSizeChange(val) {
    this.pageSize = val
    this.fetchData()
  },
  handleCurrentChange(val) {
    this.currentPage = val
    this.fetchData()
  }
}

使用第三方组件库

Element UI分页组件示例:

<template>
  <div>
    <el-table :data="tableData">
      <!-- 表格内容 -->
    </el-table>

    <el-pagination
      background
      layout="prev, pager, next"
      :total="1000">
    </el-pagination>
  </div>
</template>

Ant Design Vue分页组件示例:

vue实现表格页面分页

<a-table
  :columns="columns"
  :data-source="data"
  :pagination="{ pageSize: 10 }"
/>

自定义分页组件实现

创建可复用的分页组件:

// Pagination.vue
props: {
  total: Number,
  current: Number,
  pageSize: Number
},
methods: {
  changePage(page) {
    this.$emit('change', page)
  }
}

在父组件中使用:

<custom-pagination
  :total="total"
  :current="currentPage"
  :page-size="pageSize"
  @change="handlePageChange"
/>

性能优化建议

大数据量时采用虚拟滚动代替分页 缓存已请求的分页数据减少重复请求 添加加载状态提升用户体验 分页器显示总数和页码跳转功能

常见问题处理

页码超出范围时重置到第一页 数据为空时显示友好提示 分页参数与筛选条件联动 URL中保持分页状态便于分享链接

标签: 分页表格
分享给朋友:

相关文章

表格制作css

表格制作css

基础表格样式 使用CSS可以轻松地为HTML表格添加样式。以下是一个基础表格的HTML和CSS示例: <table class="basic-table"> <thead>…

vue实现表格追加

vue实现表格追加

实现表格数据追加的方法 在Vue中实现表格数据追加可以通过多种方式完成,主要涉及数据绑定和数组操作。以下是几种常见的方法: 数据绑定与v-for指令 通过v-for指令渲染表格数据,利用数组的co…

vue 实现跨行表格

vue 实现跨行表格

实现跨行表格的方法 在Vue中实现跨行表格可以通过多种方式完成,以下是几种常见的方法: 使用HTML原生表格 HTML原生表格支持rowspan属性,可以直接在Vue模板中使用: <tabl…

用css制作表格

用css制作表格

使用CSS制作表格 基础表格结构 HTML中表格由<table>、<tr>(行)、<th>(表头)和<td>(单元格)组成。基础结构如下: <t…

vue实现滚动分页

vue实现滚动分页

实现滚动分页的基本思路 滚动分页(Infinite Scroll)是一种常见的前端分页加载方式,当用户滚动到页面底部时自动加载下一页数据。Vue 结合现代前端工具可以轻松实现这一功能。 监听滚动事件…

vue实现横向表格

vue实现横向表格

横向表格的实现方法 在Vue中实现横向表格,可以通过调整CSS样式和数据结构来实现。横向表格与常规表格的区别在于数据的展示方向,通常需要将表头和数据行进行转置。 使用CSS Flex布局 通过Fle…