当前位置:首页 > VUE

vue 实现翻页表

2026-02-17 10:06:27VUE

Vue 实现翻页表格

使用 Vue 实现翻页表格需要结合分页组件和数据展示组件。以下是实现步骤:

安装依赖 需要安装 element-uiant-design-vue 这类 UI 库,它们提供了现成的分页组件。

npm install element-ui

基础模板结构 创建一个包含表格和分页组件的 Vue 模板。

<template>
  <div>
    <el-table :data="tableData" border>
      <el-table-column prop="id" label="ID"></el-table-column>
      <el-table-column prop="name" label="Name"></el-table-column>
    </el-table>
    <el-pagination
      @current-change="handleCurrentChange"
      :current-page="currentPage"
      :page-size="pageSize"
      :total="total"
      layout="prev, pager, next">
    </el-pagination>
  </div>
</template>

数据与分页逻辑 在 Vue 实例中定义数据和方法处理分页。

<script>
export default {
  data() {
    return {
      tableData: [],
      currentPage: 1,
      pageSize: 10,
      total: 0
    }
  },
  methods: {
    fetchData() {
      // 模拟 API 请求
      const mockData = Array.from({ length: 100 }, (_, i) => ({
        id: i + 1,
        name: `Item ${i + 1}`
      }))
      this.total = mockData.length
      this.tableData = mockData.slice(
        (this.currentPage - 1) * this.pageSize,
        this.currentPage * this.pageSize
      )
    },
    handleCurrentChange(val) {
      this.currentPage = val
      this.fetchData()
    }
  },
  mounted() {
    this.fetchData()
  }
}
</script>

样式调整 根据需要调整表格和分页组件的样式。

<style scoped>
.el-pagination {
  margin-top: 20px;
  text-align: center;
}
</style>

自定义分页逻辑

如果不使用 UI 库,可以手动实现分页功能。

模板部分

<template>
  <div>
    <table>
      <tr v-for="item in paginatedData" :key="item.id">
        <td>{{ item.id }}</td>
        <td>{{ item.name }}</td>
      </tr>
    </table>
    <button @click="prevPage" :disabled="currentPage === 1">Previous</button>
    <span>Page {{ currentPage }} of {{ totalPages }}</span>
    <button @click="nextPage" :disabled="currentPage === totalPages">Next</button>
  </div>
</template>

脚本部分

<script>
export default {
  data() {
    return {
      tableData: Array.from({ length: 100 }, (_, i) => ({
        id: i + 1,
        name: `Item ${i + 1}`
      })),
      currentPage: 1,
      pageSize: 10
    }
  },
  computed: {
    totalPages() {
      return Math.ceil(this.tableData.length / this.pageSize)
    },
    paginatedData() {
      const start = (this.currentPage - 1) * this.pageSize
      const end = start + this.pageSize
      return this.tableData.slice(start, end)
    }
  },
  methods: {
    prevPage() {
      if (this.currentPage > 1) {
        this.currentPage--
      }
    },
    nextPage() {
      if (this.currentPage < this.totalPages) {
        this.currentPage++
      }
    }
  }
}
</script>

服务器端分页

对于大量数据,建议使用服务器端分页。

API 请求示例

methods: {
  async fetchData() {
    const res = await axios.get('/api/items', {
      params: {
        page: this.currentPage,
        size: this.pageSize
      }
    })
    this.tableData = res.data.items
    this.total = res.data.total
  }
}

分页组件事件

vue 实现翻页表

<el-pagination
  @current-change="fetchData"
  @size-change="handleSizeChange">
</el-pagination>
methods: {
  handleSizeChange(val) {
    this.pageSize = val
    this.fetchData()
  }
}

以上方法提供了从基础到进阶的 Vue 翻页表格实现方案,可以根据项目需求选择适合的方式。

标签: 翻页vue
分享给朋友:

相关文章

vue实现计时

vue实现计时

Vue 实现计时功能 在 Vue 中实现计时功能可以通过多种方式完成,以下是几种常见的方法: 使用 setInterval 实现基础计时器 通过 setInterval 和 clearInterva…

vue拖拽实现

vue拖拽实现

Vue 拖拽实现方法 使用 HTML5 原生拖拽 API HTML5 提供了原生拖拽 API,可以通过 draggable 属性、dragstart、dragend、dragover 和 drop 事…

vue mvvm实现

vue mvvm实现

Vue MVVM 实现原理 Vue.js 是一个基于 MVVM(Model-View-ViewModel)模式的框架,其核心是通过数据绑定和响应式系统实现视图与数据的自动同步。以下是 Vue 实现 M…

vue nexttick实现

vue nexttick实现

Vue 中 nextTick 的实现原理 Vue 的 nextTick 是一个用于在下次 DOM 更新循环结束之后执行延迟回调的方法。它的核心实现依赖于 JavaScript 的事件循环机制。…

vue实现login

vue实现login

Vue 实现登录功能 在 Vue 中实现登录功能通常需要以下几个步骤: 创建登录表单组件 在 Vue 项目中创建一个登录表单组件,包含用户名和密码输入框以及提交按钮。可以使用 Vue 的模板语法和双…

vue 实现循环

vue 实现循环

Vue 实现循环的方法 在 Vue 中,可以使用 v-for 指令来实现循环渲染列表数据。以下是几种常见的循环实现方式: 基本数组循环 <template> <ul>…