当前位置:首页 > VUE

vue实现页面分页

2026-02-10 22:33:55VUE

分页组件实现

在Vue中实现分页功能,可以通过封装一个分页组件来完成。以下是基于Element UI的分页组件示例:

<template>
  <div class="pagination-container">
    <el-pagination
      :current-page="currentPage"
      :page-size="pageSize"
      :total="total"
      :page-sizes="[10, 20, 30, 50]"
      layout="total, sizes, prev, pager, next, jumper"
      @size-change="handleSizeChange"
      @current-change="handleCurrentChange"
    />
  </div>
</template>

<script>
export default {
  props: {
    total: {
      type: Number,
      required: true
    },
    page: {
      type: Number,
      default: 1
    },
    limit: {
      type: Number,
      default: 10
    }
  },
  data() {
    return {
      currentPage: this.page,
      pageSize: this.limit
    }
  },
  methods: {
    handleSizeChange(val) {
      this.pageSize = val
      this.$emit('pagination', { page: this.currentPage, limit: val })
    },
    handleCurrentChange(val) {
      this.currentPage = val
      this.$emit('pagination', { page: val, limit: this.pageSize })
    }
  }
}
</script>

数据请求处理

在父组件中使用分页组件并处理数据请求:

vue实现页面分页

<template>
  <div>
    <table>
      <!-- 表格内容 -->
    </table>
    <pagination
      :total="total"
      :page.sync="listQuery.page"
      :limit.sync="listQuery.limit"
      @pagination="getList"
    />
  </div>
</template>

<script>
import Pagination from '@/components/Pagination'

export default {
  components: { Pagination },
  data() {
    return {
      list: [],
      total: 0,
      listQuery: {
        page: 1,
        limit: 20
      }
    }
  },
  created() {
    this.getList()
  },
  methods: {
    getList() {
      fetchList(this.listQuery).then(response => {
        this.list = response.data.items
        this.total = response.data.total
      })
    }
  }
}
</script>

后端API配合

后端API需要接收分页参数并返回分页数据:

vue实现页面分页

// Express示例
app.get('/api/items', (req, res) => {
  const page = parseInt(req.query.page) || 1
  const limit = parseInt(req.query.limit) || 10
  const offset = (page - 1) * limit

  // 查询数据库
  const total = await Item.count()
  const items = await Item.findAll({
    offset,
    limit
  })

  res.json({
    items,
    total
  })
})

纯前端分页

对于少量数据,可以在前端实现分页:

methods: {
  handlePagination() {
    const start = (this.currentPage - 1) * this.pageSize
    const end = start + this.pageSize
    this.paginatedData = this.allData.slice(start, end)
  }
}

分页样式优化

可以自定义分页样式以适应不同需求:

.pagination-container {
  padding: 20px 0;
  text-align: center;
}

.el-pagination {
  display: inline-block;
}

以上实现方式可以根据具体项目需求进行调整,Element UI的分页组件提供了丰富的配置选项,可以满足大多数分页场景。对于不使用UI框架的项目,也可以基于原生HTML和JavaScript实现类似功能。

标签: 分页页面
分享给朋友:

相关文章

vue实现点击页面切换

vue实现点击页面切换

Vue 实现页面切换 在 Vue 中实现页面切换通常可以通过以下几种方式实现,具体选择取决于项目需求和技术栈。 使用 Vue Router 实现页面切换 Vue Router 是 Vue 官方提供的…

vue实现下拉分页思想

vue实现下拉分页思想

实现下拉分页的基本思想 下拉分页(Infinite Scroll)是一种常见的分页加载方式,当用户滚动到页面底部时自动加载下一页数据。Vue 中可以通过监听滚动事件或使用第三方库实现。 监听滚动事件…

vue分页实现

vue分页实现

Vue 分页实现方法 基础分页组件实现 创建一个简单的分页组件,包含上一页、下一页和页码按钮。组件接收当前页码、总页数等参数,通过事件通知父组件页码变化。 <template> &l…

react 如何分页

react 如何分页

分页实现方法 在React中实现分页功能可以通过多种方式完成,具体取决于数据来源(如API或本地数据)和UI库的选择。以下是常见的实现方法: 使用本地数据分页 对于存储在组件状态或Context中…

vue实现转页面

vue实现转页面

Vue 实现页面跳转的方法 在 Vue 中实现页面跳转可以通过多种方式,主要分为编程式导航和声明式导航两种。以下是具体实现方法: 使用 <router-link> 声明式导航 <r…

vue前端实现分页

vue前端实现分页

实现分页的基本思路 在Vue中实现分页通常需要结合后端API返回的数据和前端的分页组件。核心逻辑包括计算总页数、处理当前页码变化以及动态加载数据。 使用Element UI的分页组件 Elemen…