前端(Vue)实现自行分页的两种方法

前端做页面时,经常会遇到表格+分页的组合,有时因为一些原因,需要前端自己实现分页,下面介绍2种方法实现分页,
在这里插入图片描述

方法一:slice方法

slice(参数1,参数2)方法是返回一个新的数组对象
参数1:起始下标数
参数2:结束下标数(不计算在内)
data:[1,2,3,4,5,6,7,8],那么data.slice(0,3)就为下标为0,1,2,不包括下标为3的数,即[1,2,3],可以看成数学中的[0,3)

slice方法详细讲解

这个原理就和分页原理很相似,分页也是把一个很长的数组,按照每页多少条(size)分为若干个短数组
关键语句就一句:

     //allData为全部数据,tableData是目前表格绑定的数据
     this.tableData = this.allData.slice(
        (this.page - 1) * this.size,
        this.page * this.size
      );
      this.total=this.allData.length

下面是详细代码:
在这里插入图片描述
在这里插入图片描述
如果还是不能理解,可以用举例法为大家演示
data=[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19]
总条目数total=20
若设size=3(每页3条)

pagesizeslice( (page-1)×size , page×size )实际数据(表格)意义
13[0,3)[0,1,2]截取数组下标为0—3(不含3)的数据
23[3,6)[3,4,5]截取数组下标为3—6(不含6)的数据
33[6,9)[6,7,8]截取数组下标为6—9(不含9)的数据
43[9,12)[9,10,11]截取数组下标为9—12(不含12)的数据
53[12,15)[12,13,14]截取数组下标为12—15(不含15)的数据

方法二:splice方法

splice方法可以理解为删除,与方法一的slice只差一个p字母
用splice分页,需要用到的有2个参数,
splice(参数1,参数2)
参数1:从第几位开始
参数2:删除几个元素
data:[1,2,3,4,5,6,7,8],那么data.splice(0,3)就是从第0位开始,删除3个元素,即删除的元素为[1,2,3],剩余元素为data:[4,5,6,7,8]此方法会改变原数组

splice方法详细讲解

这个原理要和分页原理结合关联起来,如果一页3条数据,第一页就是从0位开始,删除的3个元素,即splice(0,3),第二页就是从第3位开始,删除的3个元素,即splice(3,3)
因此用splice分页的关键语句就是:

      let data=JSON.parse(JSON.stringify(this.allData))
      this.tableData = data.splice(
        (this.page - 1) * this.size,
        this.size
      );
      this.total=this.allData.length

注意:splice会改变原数组,因为它使用一次,相当于原数组就被删除了一些元素,必须使用深拷贝先拷贝一份allData,然后再取被删除的元素赋值给tableData

其余代码不变,只是略微改变处理完整数据的方法
在这里插入图片描述
如果还是不能理解,依然用举例法为大家演示
data=[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19]
由于深拷贝的原因,data可以等于完整的allData,
总条目数total=20
若设size=3(每页3条)

pagesizesplice( (page-1)×size , size )实际数据(表格)意义
13(0,3)[0,1,2]从第0位开始,删除的3个元素
23(3,3)[3,4,5]从第3位开始,删除的3个元素
33(6,3)[6,7,8]从第6位开始,删除的3个元素
43(9,3)[9,10,11]从第9位开始,删除的3个元素
53(12,3)[12,13,14]从第12位开始,删除的3个元素

两种方法的总结

方法名slice (参数1,参数2)splice(参数1,参数2)
参数1(page-1)*size(page-1)*size
参数2page*sizesize
意义截取删除
深浅拷贝浅拷贝深拷贝

最后完整代码如下:

<template>
  <div>
    <el-table :data="tableData" border>
      <el-table-column label="序号" type="index" width="50">
      </el-table-column>
      <el-table-column prop="date" label="日期" width="180">
      </el-table-column>
      <el-table-column prop="name" label="姓名" width="180">
      </el-table-column>
      <el-table-column prop="address" label="地址">
      </el-table-column>
    </el-table>

    <el-pagination @size-change="sizeChange" @current-change="currentChange"
      :current-page="page" :page-size="size" :page-sizes="pageSizes"
      layout="total, sizes, prev, pager, next, jumper" :total="total">
    </el-pagination>
  </div>
</template>
<script>
export default {
  data() {
    return {
      page: 1, //第几页
      size: 3, //一页多少条
      total: 0, //总条目数
      pageSizes: [3, 5, 10, 20, 50, 100, 200, 300, 400, 500, 1000], //可选择的一页多少条
      tableData: [], //表格绑定的数据
      allData: [
        {
          date: "2016-05-02",
          name: "王小虎1",
          address: "上海市普陀区金沙江路 1518 弄",
        },
        {
          date: "2016-05-04",
          name: "王小虎2",
          address: "上海市普陀区金沙江路 1517 弄",
        },
        {
          date: "2016-05-01",
          name: "王小虎3",
          address: "上海市普陀区金沙江路 1519 弄",
        },
        {
          date: "2016-05-03",
          name: "王小虎4",
          address: "上海市普陀区金沙江路 1516 弄",
        },
        {
          date: "2016-05-02",
          name: "王小虎5",
          address: "上海市普陀区金沙江路 1518 弄",
        },
        {
          date: "2016-05-04",
          name: "王小虎6",
          address: "上海市普陀区金沙江路 1517 弄",
        },
        {
          date: "2016-05-01",
          name: "王小虎7",
          address: "上海市普陀区金沙江路 1519 弄",
        },
        {
          date: "2016-05-03",
          name: "王小虎8",
          address: "上海市普陀区金沙江路 1516 弄",
        },
        {
          date: "2016-05-02",
          name: "王小虎9",
          address: "上海市普陀区金沙江路 1518 弄",
        },
        {
          date: "2016-05-04",
          name: "王小虎10",
          address: "上海市普陀区金沙江路 1517 弄",
        },
        {
          date: "2016-05-01",
          name: "王小虎11",
          address: "上海市普陀区金沙江路 1519 弄",
        },
        {
          date: "2016-05-03",
          name: "王小虎12",
          address: "上海市普陀区金沙江路 1516 弄",
        },
        {
          date: "2016-05-02",
          name: "王小虎13",
          address: "上海市普陀区金沙江路 1518 弄",
        },
        {
          date: "2016-05-04",
          name: "王小虎14",
          address: "上海市普陀区金沙江路 1517 弄",
        },
        {
          date: "2016-05-01",
          name: "王小虎15",
          address: "上海市普陀区金沙江路 1519 弄",
        },
        {
          date: "2016-05-03",
          name: "王小虎16",
          address: "上海市普陀区金沙江路 1516 弄",
        },
        {
          date: "2016-05-02",
          name: "王小虎17",
          address: "上海市普陀区金沙江路 1518 弄",
        },
        {
          date: "2016-05-04",
          name: "王小虎18",
          address: "上海市普陀区金沙江路 1517 弄",
        },
        {
          date: "2016-05-01",
          name: "王小虎19",
          address: "上海市普陀区金沙江路 1519 弄",
        },
        {
          date: "2016-05-03",
          name: "王小虎20",
          address: "上海市普陀区金沙江路 1516 弄",
        },
        {
          date: "2016-05-02",
          name: "王小虎21",
          address: "上海市普陀区金沙江路 1518 弄",
        },
        {
          date: "2016-05-04",
          name: "王小虎22",
          address: "上海市普陀区金沙江路 1517 弄",
        },
        {
          date: "2016-05-01",
          name: "王小虎23",
          address: "上海市普陀区金沙江路 1519 弄",
        },
        {
          date: "2016-05-03",
          name: "王小虎24",
          address: "上海市普陀区金沙江路 1516 弄",
        },
        {
          date: "2016-05-02",
          name: "王小虎25",
          address: "上海市普陀区金沙江路 1518 弄",
        },
        {
          date: "2016-05-04",
          name: "王小虎26",
          address: "上海市普陀区金沙江路 1517 弄",
        },
        {
          date: "2016-05-01",
          name: "王小虎27",
          address: "上海市普陀区金沙江路 1519 弄",
        },
        {
          date: "2016-05-03",
          name: "王小虎28",
          address: "上海市普陀区金沙江路 1516 弄",
        },
        {
          date: "2016-05-02",
          name: "王小虎29",
          address: "上海市普陀区金沙江路 1518 弄",
        },
        {
          date: "2016-05-04",
          name: "王小虎30",
          address: "上海市普陀区金沙江路 1517 弄",
        },
        {
          date: "2016-05-01",
          name: "王小虎31",
          address: "上海市普陀区金沙江路 1519 弄",
        },
        {
          date: "2016-05-03",
          name: "王小虎32",
          address: "上海市普陀区金沙江路 1516 弄",
        },
        {
          date: "2016-05-02",
          name: "王小虎33",
          address: "上海市普陀区金沙江路 1518 弄",
        },
        {
          date: "2016-05-04",
          name: "王小虎34",
          address: "上海市普陀区金沙江路 1517 弄",
        },
        {
          date: "2016-05-01",
          name: "王小虎35",
          address: "上海市普陀区金沙江路 1519 弄",
        },
        {
          date: "2016-05-03",
          name: "王小虎36",
          address: "上海市普陀区金沙江路 1516 弄",
        },
        {
          date: "2016-05-02",
          name: "王小虎37",
          address: "上海市普陀区金沙江路 1518 弄",
        },
        {
          date: "2016-05-04",
          name: "王小虎38",
          address: "上海市普陀区金沙江路 1517 弄",
        },
        {
          date: "2016-05-01",
          name: "王小虎39",
          address: "上海市普陀区金沙江路 1519 弄",
        },
        {
          date: "2016-05-03",
          name: "王小虎40",
          address: "上海市普陀区金沙江路 1516 弄",
        },
        {
          date: "2016-05-02",
          name: "王小虎41",
          address: "上海市普陀区金沙江路 1518 弄",
        },
        {
          date: "2016-05-04",
          name: "王小虎42",
          address: "上海市普陀区金沙江路 1517 弄",
        },
        {
          date: "2016-05-01",
          name: "王小虎43",
          address: "上海市普陀区金沙江路 1519 弄",
        },
        {
          date: "2016-05-03",
          name: "王小虎44",
          address: "上海市普陀区金沙江路 1516 弄",
        },
        {
          date: "2016-05-02",
          name: "王小虎45",
          address: "上海市普陀区金沙江路 1518 弄",
        },
        {
          date: "2016-05-04",
          name: "王小虎46",
          address: "上海市普陀区金沙江路 1517 弄",
        },
        {
          date: "2016-05-01",
          name: "王小虎47",
          address: "上海市普陀区金沙江路 1519 弄",
        },
        {
          date: "2016-05-03",
          name: "王小虎48",
          address: "上海市普陀区金沙江路 1516 弄",
        },
        {
          date: "2016-05-02",
          name: "王小虎49",
          address: "上海市普陀区金沙江路 1518 弄",
        },
        {
          date: "2016-05-04",
          name: "王小虎50",
          address: "上海市普陀区金沙江路 1517 弄",
        },
        {
          date: "2016-05-01",
          name: "王小虎51",
          address: "上海市普陀区金沙江路 1519 弄",
        },
        {
          date: "2016-05-03",
          name: "王小虎52",
          address: "上海市普陀区金沙江路 1516 弄",
        },
      ],
    };
  },
  methods: {
      //获取表格数据,自行分页(slice)
    getTabelData() {
        //allData为全部数据
      this.tableData = this.allData.slice(
        (this.page - 1) * this.size,
        this.page * this.size
      );
      this.total=this.allData.length
    },


    //获取表格数据,自行分页(splice)
    getTabelData2() {
      let data=JSON.parse(JSON.stringify(this.allData))
      this.tableData = data.splice(
        (this.page - 1) * this.size,
        this.size
      );
      this.total=this.allData.length
    },
    //page改变时的回调函数,参数为当前页码
     currentChange(val) {
      console.log("翻页,当前为第几页", val);
      this.page = val;
      this.getTabelData2();
    },
    //size改变时回调的函数,参数为当前的size
    sizeChange(val) {
      console.log("改变每页多少条,当前一页多少条数据", val);
      this.size = val;
      this.page = 1; 
      this.getTabelData2();
    },
  },
  created() {
    this.getTabelData2();
  },
};
</script>
  • 108
    点赞
  • 327
    收藏
    觉得还不错? 一键收藏
  • 16
    评论
### 回答1: 首先,需要准备好Vue和axios,然后创建一个Vue实例,在实例中定义一个data函数,用于存储分页查询的信息,包括当前页数、每页的数量和总数量等。在created函数中,调用axios来发送请求,获取分页数据。在mounted函数中,初始化分页器。在methods函数中,添加分页器的处理函数,实现点击分页器时触发axios来获取分页数据。 ### 回答2: Vue.js是一种用于构建用户界面的JavaScript框架。它具有简单易用、高效灵活的特点,因此非常适合用来开发前端分页查询程序。 首先,我们需要安装Vue.jsVue Router插件。然后创建一个Vue实例,并在该实例中定义一个组件用于处理分页查询功能。 在组件中,我们可以使用Vue的响应式数据来存储查询结果和当前页码。我们还可以使用计算属性来根据总记录数和每页显示的数据量计算总页数。 接下来,我们需要在模板中定义一个表格来显示查询结果。可以使用v-for指令来遍历查询结果数组,并显示每条记录的相关信息。 为了实现分页功能,我们可以添加两个按钮或链接,一个用于切换到上一页,另一个用于切换到下一页。当点击按钮时,我们可以调用方法来更新当前页码,并重新查询数据。 为了实现数据的异步加载和渲染,我们可以使用Axios或Fetch等工具来发送HTTP请求,并接收服务器返回的数据。 最后,我们可以在Vue实例的mounted钩子函数中调用查询方法,来初始化数据并显示第一页的查询结果。 整个过程中,我们可以使用Vue的生命周期钩子函数来管理组件的生命周期,以便在适当的时候加载数据、监听事件、更新状态等。 通过以上步骤,我们就可以构建一个基本的Vue前端分页查询程序了。当用户输入查询条件并点击查询按钮时,程序将发送请求到后端服务器并获取分页查询结果,然后将结果显示在前端界面中。用户还可以通过按钮或链接来切换不同的页码,以便查看更多的查询结果。 ### 回答3: Vue是一个用于构建用户界面的渐进式JavaScript框架。使用Vue可以轻松地构建交互式的前端应用程序。下面是一个使用Vue实现前端分页查询的示例程序。 1. 在HTML文件中引入Vue和axios,axios是一个用于进行HTTP请求的库。 ```html <html> <head> <title>前端分页查询</title> <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script> <script src="https://cdn.jsdelivr.net/npm/axios/dist/axios.min.js"></script> </head> <body> <div id="app"> <h1>前端分页查询</h1> <table> <thead> <tr> <th>ID</th> <th>Name</th> <th>Age</th> </tr> </thead> <tbody> <tr v-for="person in persons" :key="person.id"> <td>{{person.id}}</td> <td>{{person.name}}</td> <td>{{person.age}}</td> </tr> </tbody> </table> <div> <button @click="previousPage">上一页</button> <span>{{currentPage}}</span> <button @click="nextPage">下一页</button> </div> </div> <script src="script.js"></script> </body> </html> ``` 2. 在JavaScript文件中编写Vue实例和相关的方法。 ```javascript let app = new Vue({ el: '#app', data: { currentPage: 1, // 当前页码 pageSize: 10, // 每页显示的记录数 totalRecords: 0, // 总记录数 persons: [] // 查询结果 }, mounted() { this.loadData(); // 初始化时加载数据 }, methods: { loadData() { let startIndex = (this.currentPage - 1) * this.pageSize; // 计算查询起始位置 let url = `https://example.com/api/persons?startIndex=${startIndex}&pageSize=${this.pageSize}`; axios.get(url) .then(response => { this.persons = response.data; // 将查询结果赋值给persons数组 this.totalRecords = response.headers['x-total-count']; // 获取总记录数 }) .catch(error => { console.log(error); }); }, previousPage() { if (this.currentPage > 1) { this.currentPage--; this.loadData(); // 加载上一页数据 } }, nextPage() { let totalPages = Math.ceil(this.totalRecords / this.pageSize); if (this.currentPage < totalPages) { this.currentPage++; this.loadData(); // 加载下一页数据 } } } }); ``` 以上示例程序实现了一个简单的前端分页查询功能。用户可以点击“上一页”和“下一页”按钮来切换分页,并且查询结果会根据当前页码和每页记录数进行动态加载。
评论 16
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值