后端一次性返回所有的数据,让前端截取展示做分页

简介: 后端一次性返回所有的数据,让前端截取展示做分页

问题描述

有这样一个业务场景:对于某个表格展示数据而言,这个表格的数据在30~60条之间,不会超过某个数量不会太多。

后端说:我一次性返回给你所有的数据,因为产品说必须要做分页,你就自己做分页吧,也不用传我分页参数了。行吧?

前端:行,那我拿到所有的数据,根据分页参数,自己做一个截取展示呗

效果图

效果图就是正常的分页效果

GIF 2022-4-28 23-26-47.gif

代码附上

演示的话,直接复制粘贴即可。注释中简述了,代码思路

<template>
  <div class="box">
    <el-table height="240" :data="showTableData" border style="width: 100%">
      <el-table-column prop="name" label="姓名" width="180"></el-table-column>
      <el-table-column prop="age" label="年龄" width="180"></el-table-column>
      <el-table-column prop="home" label="家乡"></el-table-column>
    </el-table>
    <el-pagination
      layout="total, sizes, prev, pager, next, jumper"
      @size-change="handleSizeChange"
      @current-change="handleCurrentChange"
      :current-page="pageIndex"
      :page-size="pageSize"
      :page-sizes="[2, 4, 6, 10]"
      :total="total"
    >
    </el-pagination>
  </div>
</template>
<script>
export default {
  data() {
    return {
      pageIndex: 1, // 第几页
      pageSize: 4, // 每页几条数据
      total: 0, // 总条目数
      allTableData: [], // 所有的数据
      showTableData: [], // 当前展示的数据
    };
  },
  mounted() {
    setTimeout(() => {
      // 1. 模拟发请求获取所有的数据
      let apiAllTableData = [
        {
          name: "孙悟空",
          age: 500,
          home: "花果山水帘洞",
        },
        {
          name: "猪八戒",
          age: 88,
          home: "高老庄",
        },
        {
          name: "沙和尚",
          age: 1000,
          home: "通天河",
        },
        {
          name: "唐僧",
          age: 9999,
          home: "东土大唐",
        },
        {
          name: "白龙马",
          age: 12,
          home: "东海",
        },
        {
          name: "观音菩萨",
          age: 18,
          home: "南海",
        },
        {
          name: "玉皇大帝",
          age: 123456789,
          home: "凌霄宝殿",
        },
        {
          name: "如来佛祖",
          age: 9999999.999,
          home: "迦毗罗卫国",
        },
      ];
      // 2. 存一份所有的数据
      this.allTableData = apiAllTableData;
      // 3. 获取总条目数
      this.total = this.allTableData.length;
      // 4. 根据当前是第几页、每页展示几条,去截取需要展示的数据
      this.getShowTableData();
    }, 1000);
  },
  methods: {
    getShowTableData() {
      // 5. 获取截取开始索引
      let begin = (this.pageIndex - 1) * this.pageSize;
      // 6. 获取截取结束索引
      let end = this.pageIndex * this.pageSize;
      // 7. 通过索引去截取,从而展示
      this.showTableData = this.allTableData.slice(begin, end);
    },
    // 8. 页数改变,重新截取
    handleCurrentChange(val) {
      this.pageIndex = val;
      this.getShowTableData();
    },
    // 9. 条目数改变,也重新截取
    handleSizeChange(val) {
      this.pageIndex = 1;
      this.pageSize = val;
      this.getShowTableData();
    },
  },
};
</script>
其实对于某些数据量比较少的表格展示业务场景,完全可以不分页,或者由前端做截取分页。
相关文章
|
11天前
|
前端开发 JavaScript 关系型数据库
从前端到后端:构建现代化Web应用的技术探索
在当今互联网时代,Web应用的开发已成为了各行各业不可或缺的一部分。从前端到后端,这篇文章将带你深入探索如何构建现代化的Web应用。我们将介绍多种技术,包括前端开发、后端开发以及各种编程语言(如Java、Python、C、PHP、Go)和数据库,帮助你了解如何利用这些技术构建出高效、安全和可扩展的Web应用。
|
12天前
|
前端开发 小程序 Java
uniapp上传图片 前端以及java后端代码实现
uniapp上传图片 前端以及java后端代码实现
28 0
|
29天前
|
JSON 前端开发 Java
layui上传图片,前端直接拷代码,后端……
layui上传图片,前端直接拷代码,后端……
26 0
|
3天前
|
存储 缓存 前端开发
前端如何利用indexDB进行数据优化
使用IndexedDB作为浏览器内置的客户端数据库,用于存储大量数据和实现离线支持。它能缓存常用数据,减少服务器请求,提高用户体验。IndexedDB支持数据索引、复杂查询及版本管理,允许离线操作并同步到服务器。但需熟悉其异步API,可借助Dexie.js、localForage等库简化使用。
|
7天前
|
小程序 前端开发 JavaScript
小程序全栈开发:前端与后端的完美结合
【4月更文挑战第12天】本文介绍了小程序全栈开发,涵盖前端和后端的关键点。前端使用WXML和WXSS进行页面结构和样式设计,JavaScript处理逻辑及组件使用;后端采用Node.js等语言处理业务逻辑、数据库设计和API接口开发。前端与后端通过数据交互实现结合,采用前后端分离模式,支持跨平台运行。调试测试后,提交微信审核并上线运营。掌握前端后端结合是小程序成功的关键。
|
7天前
|
Web App开发 移动开发 运维
跨域解决方案[前端+后端]
跨域解决方案[前端+后端]
21 0
|
9天前
|
JavaScript 前端开发 API
游戏开发入门:Python后端与Vue前端的协同工作方式
【4月更文挑战第11天】使用Python后端(Flask或Django)和Vue.js前端开发游戏变得流行,能提高开发效率和可维护性。本文指导如何构建这样的项目,包括设置环境、创建虚拟环境、搭建后端API及前端Vue组件,强调前后端协作和API接口的重要性。这种架构促进团队合作,提升代码质量和游戏体验。
|
9天前
|
供应链 JavaScript 前端开发
使用Django和Vue实现电子商务网站的后端和前端
【4月更文挑战第10天】本文介绍了使用Django和Vue构建电子商务网站的后端与前端方法。Django作为Python的Web框架负责后端,其模型-视图-控制器设计简化了商品管理、购物车和订单处理。Vue.js用于前端,提供数据驱动和组件化的用户界面。通过定义Django模型和视图处理请求,结合Vue组件展示商品和管理购物车,开发者可构建交互性强的电商网站。虽然实际开发涉及更多细节,但本文为入门提供了基础指导。
|
23天前
|
前端开发 JavaScript NoSQL
从前端到后端:构建全栈应用的技术挑战与解决方案
在当今互联网时代,全栈开发成为越来越受欢迎的技术趋势。本文将深入探讨从前端到后端的全栈开发过程中所面临的技术挑战,并提出相应的解决方案,涵盖前端框架选择、后端技术架构、数据库设计以及跨平台兼容性等关键问题。
|
29天前
|
前端开发 JavaScript NoSQL
从前端到后端:构建全栈开发的技术生态
本文将探讨如何在全栈开发中构建完整的技术生态,从前端到后端各个层面进行深入剖析,讨论不同技术之间的协作与整合,为开发人员提供全面的指导与启示。