当前位置:首页 > VUE

vue分页插件实现

2026-02-17 09:33:26VUE

Vue 分页插件实现方法

使用第三方库(推荐)

安装 vuejs-paginatev-pagination 等成熟分页库:

npm install vuejs-paginate

注册组件:

import Vue from 'vue'
import VuePaginate from 'vuejs-paginate'
Vue.component('paginate', VuePaginate)

模板中使用:

<paginate
  :page-count="totalPages"
  :click-handler="changePage"
  :prev-text="'Prev'"
  :next-text="'Next'"
  :container-class="'pagination'"
/>

自定义分页组件

创建 Pagination.vue 组件:

<template>
  <div class="pagination">
    <button @click="prevPage" :disabled="currentPage === 1">Previous</button>
    <span v-for="page in pages" :key="page">
      <button 
        @click="goToPage(page)"
        :class="{ active: currentPage === page }"
      >{{ page }}</button>
    </span>
    <button @click="nextPage" :disabled="currentPage === totalPages">Next</button>
  </div>
</template>

<script>
export default {
  props: {
    totalItems: Number,
    itemsPerPage: Number,
    currentPage: Number
  },
  computed: {
    totalPages() {
      return Math.ceil(this.totalItems / this.itemsPerPage)
    },
    pages() {
      const range = []
      for (let i = 1; i <= this.totalPages; i++) {
        range.push(i)
      }
      return range
    }
  },
  methods: {
    prevPage() {
      this.$emit('page-changed', this.currentPage - 1)
    },
    nextPage() {
      this.$emit('page-changed', this.currentPage + 1)
    },
    goToPage(page) {
      this.$emit('page-changed', page)
    }
  }
}
</script>

与数据结合使用

父组件中实现分页逻辑:

data() {
  return {
    currentPage: 1,
    itemsPerPage: 10,
    allItems: [...] // 你的完整数据
  }
},
computed: {
  paginatedItems() {
    const start = (this.currentPage - 1) * this.itemsPerPage
    const end = start + this.itemsPerPage
    return this.allItems.slice(start, end)
  }
},
methods: {
  handlePageChange(page) {
    this.currentPage = page
  }
}

样式定制

添加基础CSS样式:

.pagination {
  display: flex;
  justify-content: center;
  margin-top: 20px;
}

.pagination button {
  margin: 0 5px;
  padding: 5px 10px;
  border: 1px solid #ddd;
  background: #fff;
  cursor: pointer;
}

.pagination button.active {
  background: #007bff;
  color: white;
  border-color: #007bff;
}

.pagination button:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

高级功能扩展

对于大型数据集:

vue分页插件实现

  • 添加页面跳转输入框
  • 实现动态页码范围计算(只显示当前页附近的页码)
  • 添加每页条数选择器
  • 结合路由实现URL同步
// 动态页码计算示例
pages() {
  const range = []
  const maxVisible = 5
  let start = Math.max(1, this.currentPage - Math.floor(maxVisible/2))
  let end = Math.min(this.totalPages, start + maxVisible - 1)

  if (end - start + 1 < maxVisible) {
    start = Math.max(1, end - maxVisible + 1)
  }

  for (let i = start; i <= end; i++) {
    range.push(i)
  }

  return range
}

标签: 分页插件
分享给朋友:

相关文章

vue实现皮肤插件

vue实现皮肤插件

实现思路 Vue实现皮肤插件通常通过动态切换CSS变量或类名实现。核心思路是将皮肤样式抽离为独立的CSS文件或变量,通过用户交互或配置切换不同的皮肤主题。 基础实现方案 定义皮肤变量 在全局CSS中…

vue实现后台分页

vue实现后台分页

Vue 实现后台分页的方法 分页组件与数据绑定 在 Vue 中实现后台分页通常需要结合分页组件和后端 API。使用 el-pagination(Element UI)或自定义分页组件,通过 v-mod…

vue实现小说分页

vue实现小说分页

实现小说分页功能 Vue.js可以通过计算属性、动态渲染和分页逻辑实现小说分页功能。以下是具体实现方法: 数据准备 需要将小说内容存储为字符串或数组格式,建议按章节拆分: data() { r…

uniapp 路由插件

uniapp 路由插件

在UniApp中,路由管理通常依赖框架内置的页面跳转API,但若需要更高级的路由功能(如动态路由、拦截器等),可通过以下插件或方案实现: 路由插件推荐 uni-simple-router 专为Uni…

vue实现预热插件

vue实现预热插件

Vue 预热插件实现方法 预热插件(Preheat Plugin)通常用于在 Vue 应用初始化前预加载数据或执行必要操作,提升用户体验。以下是实现方案: 插件基本结构 创建 preheat-plu…

vue实现图片插件

vue实现图片插件

Vue 图片插件实现方案 在 Vue 中实现图片插件通常涉及图片展示、懒加载、预览等功能。以下是几种常见的实现方式: 基础图片组件封装 创建一个可复用的图片组件,支持默认图片、加载失败处理等基础功能…