注:本文分页组件用原生 html + css 实现,element-ui里有专门的分页组件可以不用自己写,详情见另一篇博客:https://www.cnblogs.com/zdd2017/p/11153527.html

表格分页有两种实现方式:前端分页和后端分页。前端分页会一次性从后端拿到所有数据,然后分页展示在页面上,适合数据量比较小的情况;后端分页是每次从后端拿到当前页的数据展示在页面上,也就是说每次切换页码时都要向后端发起请求,适合数据量比较大的情况。本文采用后端分页,要介绍的是采用后端分页方法时的前端写法。

首先我们写一个分页组件 pagination.vue, 效果如下:

我们来分析一下这个组件的实现,首先"《" 、"首页"、 "尾页" 、"》" 这四个地方是固定不变的,再定义一个变量pageGroup表示分页条数,这里的pageGroup=5,大于5的时候右边会出现"...",当前页大于Math.ceil(pageGroup / 2)时左边会出现"..."。选择页码时,显示的分页也会跟着变化,这里我们用一个数组存储所有页码,然后根据点击的页码分割数组得到想要的部分,下面来看一下具体实现代码:

<template>
<nav>
<ul class="pagination">
<li :class="{'disabled': current == 1}"><a href="javascript:;" @click="setCurrent(current - 1)"> « </a></li>
<li :class="{'disabled': current == 1}"><a href="javascript:;" @click="setCurrent(1)"> 首页 </a></li>
<li v-for="p in grouplist" :key="p.id" :class="{'active': current == p.val}">
<a href="javascript:;" @click="setCurrent(p.val)"> {{ p.text }} </a>
</li>
<li :class="{'disabled': current == page}"><a href="javascript:;" @click="setCurrent(page)"> 尾页 </a></li>
<li :class="{'disabled': current == page}"><a href="javascript:;" @click="setCurrent(current + 1)"> »</a></li>
</ul>
</nav>
</template>
<script type="es6">
export default{
data () {
return {
current: this.currentPage
};
},
props: {
total: {// 数据总条数
type: Number,
default: 0
},
display: {// 每页显示条数
type: Number,
default: 10
},
currentPage: {// 当前页码
type: Number,
default: 1
},
pagegroup: {// 分页条数
type: Number,
default: 5,
coerce: function (v) {
v = v > 0 ? v : 5;
return v % 2 === 1 ? v : v + 1;
}
}
},
computed: {
page: function () { // 总页数
return Math.ceil(this.total / this.display);
},
grouplist: function () { // 获取分页页码
let len = this.page;
let temp = [];
let list = [];
let count = Math.floor(this.pagegroup / 2);
let center = this.current;
if (len <= this.pagegroup) {
for (let i = 1; i <= len; i++) {
list.push({text: i, val: i});
}
return list;
}
for (let i = 1; i <= this.page; i++) {
temp.push(i);
}
(center < count + 1) && (center = count + 1); // 当前页是开头几页时保持center是count + 1不变
(center > this.page - count) && (center = this.page - count); // 当前页是末尾几页时保持center是this.page-count不变
temp = temp.splice(center - count - 1, this.pagegroup);
for (let j = 0; j < temp.length; j++) {
list.push({
text: temp[j],
val: temp[j]
});
}
(this.current > count + 1) && list.unshift({text: '...', val: list[0].val - 1});
(this.current < this.page - count) && list.push({text: '...', val: list[list.length - 1].val + 1});
return list;
}
},
methods: {
setCurrent: function (idx) {
if (this.current !== idx && idx > 0 && idx < this.page + 1) {
this.current = idx;
this.$emit('pagechange', this.current);
}
}
}
};
</script>
<style lang="less">
.pagination {
overflow: hidden;
display: table;
margin: 0 auto;
height: 30px;
border: 1px solid rgb(241, 241, 241);
border-radius: 5px;
li {
list-style:none;
float: left;
height: 30px;
border-radius: 5px;
margin: 3px;
&:hover {
background: #000;
a {
color: #fff;
}
}
a {
display: block;
width: 30px;
height: 30px;
text-align: center;
line-height: 30px;
font-size: 12px;
color: #666;
text-decoration: none
}
}
.active {
background: #000;
a {
color: #fff;
}
}
}
</style>

然后我们在父组件里去引用这个分页组件,用vue2.0 + Element UI写好表格,并传参给分页组件

<template>
<div class="index">
<div class="grid">
<el-table :data="tableData" border style="margin-bottom:14px;">
<el-table-column width="55" type="selection" align="center"></el-table-column>
<el-table-column property="id" label="队列号" align="center"></el-table-column>
<el-table-column property="queueName" label="队列名" align="center"></el-table-column>
<el-table-column property="filed" label="队列内容" align="center"></el-table-column>
<el-table-column property="hdfsdir" label="hdfs目录" align="center"></el-table-column>
<el-table-column property="localDir" label="本地目录" align="center"></el-table-column>
</el-table>
<v-pagination :total="total" :display="display" :current-page='current' @pagechange="pagechange"></v-pagination>
</div>
</div>
</template>

在data里注册需要用到的一些变量

data () {
return {
tableData: [],
total: 0,
limit: 10,
current: 1
};
}

现在我们需要向后端请求数据,需要传给后端的参数是当前页即首页currenPage=1以及每页显示的数据量(这里假设为10)

created () {
Axios.get('/queue/online?page=1&limit=10')
.then((response) => {
// list数组是后端返回的10条数据
this.tableData = response.data.list;
})
.catch((error) => {
console.log(error);
});
},

这样我们表格中就出现了从后端拿到的第一页的10条数据,当我们点击页码时,也要向后端重新发起请求

methods: {
pagechange (currentPage) {
// console.log(currentPage); // ajax请求, 向后台发送 currentPage, 来获取对应的数据
Axios.get('/queue/online?page=' + currentPage + '&limit=' + this.display)
.then((response) => {
this.tableData = response.data.list;
})
.catch((error) => {
console.log(error);
});
}
}

至此已可实现表格分页效果,希望能对大家有所帮助。

vue2.0 + Element UI + axios实现表格分页的更多相关文章

  1. Vue2.0+ElementUI+PageHelper实现的表格分页

    Vue2.0+ElementUI+PageHelper实现的表格分页 前言 最近做了一些前端的项目,要对表格进行一些分页显示.表格分页的方法有很多,从宏观上来说分为物理分页和逻辑分页,由于逻辑分页(即 ...

  2. vue2.0+Element UI 表格前端分页和后端分页

    之前写过一篇博客,当时对element ui框架还不太了解,分页组件用 html + css 自己写的,比较麻烦,而且只提到了后端分页 (见 https://www.cnblogs.com/zdd20 ...

  3. vue2.0 + element ui 实现表格穿梭框

    element ui 官网里介绍了穿梭框(Transfer),但在实际使用过程中,会出现一些问题: 1.穿梭框里能放置的内容太少,不能满足复杂的业务需求. 2.当选项过多时,穿梭框很难实现分页,左右两 ...

  4. vue2.0+Element UI 实现动态表单(点击按钮增删一排输入框)

    对于动态增减表单项,Element UI 官方文档表单那一节已经介绍得很清楚了,我之前没有看见,绕了很多弯路,这里针对点击按钮增删一排输入框的问题做一个总结. 效果图如下 存在一排必填的姓名与手机号, ...

  5. vue2.0 element学习

    1,bootstrap和vue2.0结合使用 vue文件搭建好后,引入jquery和bootstrap 我采用的方式为外部引用 在main.js内部直接导入 用vue-cli直接安装jquery和bo ...

  6. element ui table(表格)点击一行展开

    element ui是一个非常不错的vue的UI框架,element对table进行了封装,简化了vue对表格的渲染. element ui表格中有一个功能是展开行,在2.0版本官网例子中,只可以点击 ...

  7. vue+element UI + axios封装文件上传及进度条组件

    1.前言 之前在做项目的时候,需要实现一个文件上传组件并且需要有文件上传进度条,现将之前的实现过程简单记录一下,希望可以帮助到有需要的人. 项目用的是Vue框架,UI库使用的是element UI,前 ...

  8. vue2.0+element+node+webpack搭建的一个简单的后台管理界面

    闲聊: 今天是六一儿童节哟,小颖祝大家节日快乐哈哈哈.其实这个demo小颖断断续续做了将近两个礼拜了,心塞的,其实这个也没有多难,主要是小颖有点最近事情有点多,所以就把这个一直拖着,今天好不容易做好了 ...

  9. 2021新年 Vue3.0 + Element UI 尝鲜小记

    2021年,又是新的一年,Vue 已经发布 3.0 版本,最好用的 UI 组件库 Element UI 也发布了适配 Vue3.0 的新版本,是时候开始学习一下这两个新技术. 本文主要记录了使用 Vu ...

随机推荐

  1. Django模板之模板继承(extends/block)

    Django模版引擎中最强大也是最复杂的部分就是模版继承了.模版继承可以让您创建一个基本的“骨架”模版,它包含您站点中的全部元素,并且可以定义能够被子模版覆盖的 block. 模板继承: 1.    ...

  2. Java常用设计模式详解1--单例模式

    单例模式:指一个类有且仅有一个实例 由于单例模式只允许有一个实例,所以单例类就不可通过new来创建,而所有对象都默认有一个无参的构造函数可以创建对象,所以单例类不仅不能提供public的构造方法,还需 ...

  3. 树点分治入门题poj1741

    Tree Time Limit: 1000MS   Memory Limit: 30000K Total Submissions: 24253   Accepted: 8060 Description ...

  4. C语言关于数据类型转换

    自动类型转换 自动类型转换就是编译器默默地.隐式地.偷偷地进行的数据类型转换,这种转换不需要程序员干预,会自动发生. 1) 将一种类型的数据赋值给另外一种类型的变量时就会发生自动类型转换,例如: ; ...

  5. Vue全局组件创建三种方法

    <my-com1></my-com1> <my-com2></my-com2> <template id="tmp1"> ...

  6. async/await 内幕【译文】

    C# Under the Hood: async/await 原文地址:https://www.markopapic.com/csharp-under-the-hood-async-await/ 前言 ...

  7. 新来的老大,剑走偏锋,干掉AOP做操作日志,实现后我们都惊呆了

    前言 用户在操作我们系统的过程中,针对一些重要的业务数据进行增删改查的时候,我们希望记录一下用户的操作行为,以便发生问题时能及时的找到依据,这种日志就是业务系统的操作日志. 本篇我们来探讨下常见操作日 ...

  8. vue路由中使用keep-alive 以及activated和deactivated 钩子

    本次只是记录下开发中碰到的问题. 最近做一个活动页面,涉及到角色和权限的问题,需要跳转很多页面,于是vue-router走起,顺便keep-alive也用起来了,嗯,跳转的很爽,但是一个详情页面组件, ...

  9. 使用PInvoke互操作,让C#和C++愉快的交互优势互补

    一:背景 1. 讲故事 如果你常翻看FCL的源码,你会发现这里面有不少方法借助了C/C++的力量让C#更快更强悍,如下所示: [DllImport("QCall", CharSet ...

  10. Spring-boot01

    本文记录Spring-Boot学习途中的点点滴滴. 其实Spring-Boot出来好长时间了,但是一直没去关注过.之前在我的印象里Spring-Boot好就好在减去了很多XML配置,加入了很多自动配置 ...