当前位置:首页 > VUE

vue表格如何实现分页

2026-01-21 14:32:48VUE

Vue 表格分页实现方法

在 Vue 中实现表格分页通常需要结合前端分页逻辑和后端 API 支持。以下是两种常见实现方式:

前端分页实现(适合数据量较小的情况)

安装依赖(如使用 Element UI):

npm install element-ui

代码示例:

<template>
  <div>
    <el-table :data="currentPageData" border>
      <el-table-column prop="name" label="姓名"></el-table-column>
      <el-table-column prop="age" label="年龄"></el-table-column>
    </el-table>

    <el-pagination
      @current-change="handleCurrentChange"
      :current-page="currentPage"
      :page-size="pageSize"
      :total="total">
    </el-pagination>
  </div>
</template>

<script>
export default {
  data() {
    return {
      tableData: [], // 所有数据
      currentPage: 1,
      pageSize: 10,
      total: 0
    }
  },
  computed: {
    currentPageData() {
      const start = (this.currentPage - 1) * this.pageSize
      const end = start + this.pageSize
      return this.tableData.slice(start, end)
    }
  },
  methods: {
    handleCurrentChange(val) {
      this.currentPage = val
    }
  }
}
</script>

后端分页实现(推荐大数据量场景)

API 请求示例:

methods: {
  fetchData() {
    const params = {
      page: this.currentPage,
      size: this.pageSize
    }
    axios.get('/api/data', { params })
      .then(res => {
        this.tableData = res.data.list
        this.total = res.data.total
      })
  },
  handleCurrentChange(val) {
    this.currentPage = val
    this.fetchData()
  }
}

自定义分页组件实现

核心逻辑:

function paginate(array, pageSize, pageNumber) {
  return array.slice((pageNumber - 1) * pageSize, pageNumber * pageSize)
}

模板部分:

vue表格如何实现分页

<div v-for="item in paginatedData">{{ item.name }}</div>
<button @click="prevPage">上一页</button>
<span>第{{ currentPage }}页</span>
<button @click="nextPage">下一页</button>

关键注意事项

  • 大数据量(超过 1000 条)建议使用后端分页
  • 分页组件应显示总页数和当前页码
  • 添加 loading 状态提升用户体验
  • 考虑添加每页显示条数选择器

以上方法可根据具体项目需求选择使用,Element UI 和 Ant Design Vue 等组件库已提供成熟的分页组件,可直接集成使用。

分享给朋友:

相关文章

vue如何实现放大缩小

vue如何实现放大缩小

Vue 实现放大缩小功能 在 Vue 中实现放大缩小功能可以通过多种方式实现,以下介绍几种常见的方法: 使用 CSS transform 缩放 通过绑定 CSS 的 transform: scale…

vue实现分页表

vue实现分页表

Vue 实现分页表格 在 Vue 中实现分页表格通常需要结合表格组件和分页组件,以下是常见的实现方法: 使用 Element UI 实现分页表格 安装 Element UI: npm instal…

vue分页如何实现

vue分页如何实现

实现Vue分页的方法 使用Element UI的分页组件 安装Element UI库后,可以直接使用其分页组件。需要在Vue组件中引入el-pagination,并通过v-model绑定当前页码,监听…

vue实现分页6

vue实现分页6

Vue实现分页的6种方法 基础分页组件实现 使用Vue的v-for指令和计算属性实现基础分页功能。通过计算总页数并动态渲染页码按钮,结合v-model绑定当前页码。 <template>…

vue如何实现循环

vue如何实现循环

Vue 中实现循环的方法 Vue 提供了 v-for 指令来实现循环渲染,可以遍历数组、对象或数字范围。 遍历数组 <ul> <li v-for="(item, index)…

vue实现分页教程

vue实现分页教程

Vue 分页实现方法 基础分页组件实现 创建一个简单的分页组件,包含页码按钮、上一页和下一页按钮。使用 v-for 循环生成页码,并通过 v-model 绑定当前页。 <template&g…