当前位置:首页 > 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实现常见效果的几种典型方法,分为不同场景说明: 数据绑定与响应式更新 使用v-model实现表单双向绑定: <template> <input v-model="…

vue 实现闪烁

vue 实现闪烁

Vue 实现闪烁效果的方法 方法一:使用 CSS 动画 在 Vue 组件中定义一个闪烁的 CSS 动画,通过绑定 class 或 style 来控制元素的闪烁效果。 <template>…

vue 实现表单

vue 实现表单

Vue 表单实现方法 Vue.js 提供了多种方式实现表单,包括双向数据绑定、表单验证和动态表单生成。以下是常见的实现方法: 基础表单绑定 使用 v-model 指令实现表单元素与数据的双向绑定:…

vue实现导出

vue实现导出

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

vue实现分发

vue实现分发

Vue 实现分发的方法 在 Vue 中,分发(Distribution)通常指的是将内容从父组件传递到子组件,或者通过插槽(Slots)机制让父组件控制子组件的部分渲染内容。以下是几种常见的实现分发的…

vue实现tap

vue实现tap

Vue 实现 Tap 事件 在移动端开发中,Tap 事件比 Click 事件更常用,因为 Click 事件有 300ms 延迟。以下是几种在 Vue 中实现 Tap 事件的方法。 使用第三方库 安装…