当前位置:首页 > VUE

Vue如何实现结果分页

2026-02-21 19:19:48VUE

Vue 实现结果分页的方法

使用 Element UI 的分页组件

Element UI 提供了现成的分页组件 el-pagination,可以快速实现分页功能。安装 Element UI 后,在组件中引入并使用分页组件。

<template>
  <div>
    <el-table :data="currentPageData">
      <!-- 表格内容 -->
    </el-table>
    <el-pagination
      @current-change="handleCurrentChange"
      :current-page="currentPage"
      :page-size="pageSize"
      :total="totalData.length"
      layout="prev, pager, next"
    >
    </el-pagination>
  </div>
</template>

<script>
export default {
  data() {
    return {
      totalData: [], // 所有数据
      currentPage: 1,
      pageSize: 10,
    };
  },
  computed: {
    currentPageData() {
      const start = (this.currentPage - 1) * this.pageSize;
      const end = start + this.pageSize;
      return this.totalData.slice(start, end);
    },
  },
  methods: {
    handleCurrentChange(val) {
      this.currentPage = val;
    },
  },
};
</script>

手动实现分页逻辑

如果不使用 UI 框架,可以通过计算属性手动实现分页逻辑。

Vue如何实现结果分页

<template>
  <div>
    <table>
      <tr v-for="item in currentPageData" :key="item.id">
        <td>{{ item.name }}</td>
      </tr>
    </table>
    <button @click="prevPage">上一页</button>
    <span>{{ currentPage }}</span>
    <button @click="nextPage">下一页</button>
  </div>
</template>

<script>
export default {
  data() {
    return {
      totalData: [], // 所有数据
      currentPage: 1,
      pageSize: 10,
    };
  },
  computed: {
    currentPageData() {
      const start = (this.currentPage - 1) * this.pageSize;
      const end = start + this.pageSize;
      return this.totalData.slice(start, end);
    },
  },
  methods: {
    prevPage() {
      if (this.currentPage > 1) {
        this.currentPage--;
      }
    },
    nextPage() {
      if (this.currentPage < Math.ceil(this.totalData.length / this.pageSize)) {
        this.currentPage++;
      }
    },
  },
};
</script>

使用第三方库

如果需要更复杂的分页功能,可以考虑使用第三方库如 vue-paginatev-pagination。这些库提供了更多自定义选项和功能。

安装 vue-paginate

Vue如何实现结果分页

npm install vue-paginate

使用示例:

<template>
  <div>
    <ul>
      <li v-for="item in paginatedData" :key="item.id">
        {{ item.name }}
      </li>
    </ul>
    <paginate
      v-model="currentPage"
      :page-count="totalPages"
      :click-handler="changePage"
      :prev-text="'Prev'"
      :next-text="'Next'"
    >
    </paginate>
  </div>
</template>

<script>
import Paginate from 'vue-paginate';
export default {
  components: {
    Paginate,
  },
  data() {
    return {
      totalData: [], // 所有数据
      currentPage: 1,
      pageSize: 10,
    };
  },
  computed: {
    paginatedData() {
      const start = (this.currentPage - 1) * this.pageSize;
      const end = start + this.pageSize;
      return this.totalData.slice(start, end);
    },
    totalPages() {
      return Math.ceil(this.totalData.length / this.pageSize);
    },
  },
  methods: {
    changePage(pageNum) {
      this.currentPage = pageNum;
    },
  },
};
</script>

后端分页

如果数据量很大,建议在后端实现分页逻辑,前端仅发送分页参数并接收分页后的数据。

<template>
  <div>
    <table>
      <tr v-for="item in data" :key="item.id">
        <td>{{ item.name }}</td>
      </tr>
    </table>
    <el-pagination
      @current-change="fetchData"
      :current-page="currentPage"
      :page-size="pageSize"
      :total="total"
      layout="prev, pager, next"
    >
    </el-pagination>
  </div>
</template>

<script>
export default {
  data() {
    return {
      data: [],
      currentPage: 1,
      pageSize: 10,
      total: 0,
    };
  },
  methods: {
    fetchData(page) {
      axios.get('/api/data', {
        params: {
          page,
          pageSize: this.pageSize,
        },
      }).then((res) => {
        this.data = res.data.list;
        this.total = res.data.total;
      });
    },
  },
  created() {
    this.fetchData(this.currentPage);
  },
};
</script>

分享给朋友:

相关文章

vue分页实现

vue分页实现

实现Vue分页的几种方法 使用Element UI的分页组件 安装Element UI库后,可以直接使用其分页组件。以下是一个基本示例: <template> <div>…

php如何实现直播

php如何实现直播

实现直播功能的方法 PHP可以通过结合其他技术和工具来实现直播功能。以下是几种常见的方法: 使用流媒体服务器 配置流媒体服务器如Nginx-RTMP、Red5或Wowza。这些服务器支持RTM…

h5实现左右分页

h5实现左右分页

实现左右分页的HTML5方法 在HTML5中实现左右分页效果可以通过多种方式完成,以下是几种常见的方法: 使用CSS Flexbox布局 Flexbox是一种现代的布局方式,可以轻松实现左右分页效果…

vue如何实现拖动

vue如何实现拖动

Vue 实现拖动的常用方法 使用 HTML5 原生拖放 API HTML5 提供了原生的拖放 API,可以通过 draggable 属性和相关事件实现拖动功能。 <template>…

vue如何实现mvvm

vue如何实现mvvm

Vue 的 MVVM 实现原理 Vue 通过数据绑定和响应式系统实现 MVVM(Model-View-ViewModel)模式。其核心在于将数据模型(Model)与视图(View)通过 ViewMod…

java如何实现异步

java如何实现异步

Java实现异步的方法 Java中实现异步编程可以通过多种方式,每种方式适用于不同的场景和需求。以下是常见的实现方法: 使用Thread类 创建新线程执行异步任务是最基础的方式。通过继承Threa…