当前位置:首页 > 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>

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

vue 实现翻页表

<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>

脚本部分

vue 实现翻页表

<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
  }
}

分页组件事件

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

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

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

相关文章

vue实现下拉刷新组件

vue实现下拉刷新组件

实现下拉刷新组件的核心思路 下拉刷新功能通常通过监听触摸事件、滚动位置和动画效果实现。Vue中可以利用自定义指令或封装组件完成,以下为两种常见实现方式。 基于自定义指令的实现 创建指令监听触摸事件,…

vue实现旋转

vue实现旋转

Vue 实现旋转效果的方法 在 Vue 中实现旋转效果可以通过多种方式完成,以下是几种常见的方法: 使用 CSS 动画 通过 Vue 的 :class 或 :style 绑定 CSS 动画实现旋转…

vue 实现单选

vue 实现单选

使用 v-model 绑定单选值 在 Vue 中,可以通过 v-model 绑定单选按钮的值。定义一个响应式数据(如 selectedOption),并将其与单选按钮的 value 属性关联。…

vue实现导出

vue实现导出

Vue 实现导出功能的方法 在 Vue 项目中实现导出功能通常涉及将数据导出为 Excel、CSV 或其他格式。以下是几种常见的实现方式: 使用 xlsx 库导出 Excel 安装 xlsx 库:…

vue实现动画

vue实现动画

Vue 实现动画的方法 Vue 提供了多种方式来实现动画效果,包括内置的过渡系统、第三方动画库以及直接操作 CSS 或 JavaScript 动画。 使用 Vue 内置过渡系统 Vue 的 <…

vue 实现全屏

vue 实现全屏

Vue 实现全屏功能 在 Vue 中实现全屏功能可以通过浏览器提供的 Fullscreen API 完成。以下是一个完整的实现方案: 安装依赖(可选) 如果需要跨浏览器兼容性更好,可以安装 sc…