分页是项目中常会用到的,网上的插件也很多,但是有些功能太齐全反而不是必要的,所以抽时间自己写了一下(小白写代码,若发现问题还请及时赐教,感激不尽……)

如图,想要一个这样的页码:

  a. 上一页、下一页固定展示

  b. 第一页、最后一页固定展示

  c. 中间,即:左右...之间需要展示的页码个数可自定义

  d. 可任意选择页面展示数据条数

一、不需要展示 ,只展示页码,需要定义3个变量:pageNum(当前页码)、totalNum(总页码)、middleSize(中间,即左右...之间需要展示的页码 个数)

  1、totalNum <= middleSize+2时,只显示1,2,3,4没有...,(为什么是totalNum <= middleSize+2,而不是totalNum <= middleSize,这是因为第一个、最后一页是固定展示的),totalNum=7,middleSize=5,展示情况如下图:

  2、pageNum <= middleSize时,右侧...显示,totalNum=8,middleSize=5,展示情况如下图:

  3、pageNum >= totalNum - ( middleSize - 1 )时,左侧...显示,totalNum=100, middleSize=5,展示情况如下图:

  4、除以上3种情况,左右两侧...都展示,那中间页码如何展示,代码如下:

// ④ 展示左右两侧的'...'
let pages = [1, '...'];
// 当左右两侧的...都展示时,中间的页码该如何展示呢?其实就是 当前页码 - (中间要展示页码的个数/2向下取整) 到 当前页码 + (中间要展示页码的个数/2向下取整)即可
const half = Math.floor(this.middleSize/2); // 向下取整
for(let i=this.pageNum-half; i<=this.pageNum+half; i++) {
pages.push(i);
}
pages.push('...');
pages.push(this.totalNum);
return pages;

二、左侧页面展示条数代码实现较简单,可查看全部代码:

 <template>
<div class="pageContainer">
<!-- 当前页面展示多少条数据 -->
<div class="pageSizeInner">
<div class="totalCount">共 {{totalCount}} 条</div>
<div class="pageSize">
<select v-model="perPageCount" @change="changePerPageCount">
<option :value="item" v-for="(item, index) in page_size" :key="index">{{item}}</option>
</select>
</div>
</div> <!-- 页码部分 -->
<ul class="pagesInner">
<!-- 上一页 -->
<li class="page" :class="{noClick : pageNum == 1}" @click="preOrNext(-1)">
<span>上一页</span>
</li>
<!-- 页码 -->
<li class="page" :class="{actived : item === pageNum}" v-for="(item, index) in displayPages" :key="index" @click="select(item)">
<span>{{item}}</span>
</li>
<!-- 下一页 -->
<li class="page" :class="{noClick : pageNum == totalNum}" @click="preOrNext(1)">
<span>下一页</span>
</li>
</ul>
</div>
</template> <script>
export default {
data() {
return {
totalCount: 9999, // 总共多少条数据
page_size: ['100条/页', '200条/页', '300条/页', '400条/页'], // 每页展示多少条数据
pageNum: 1, // 当前页码
totalNum: 20, // 总页码
middleSize: 5, // 中间显示几个页码
perPageCount: 0, // 每页展示多少条数据
}
},
computed: {
// 展示页码
displayPages() {
// ① 只展示'上一页'、'页码'、'下一页'
if(this.totalNum <= this.middleSize + 2) {
let pages = [];
for(let i=1; i<=this.totalNum; i++) {
pages.push(i);
}
return pages;
}else if(this.pageNum <= this.middleSize) { // this.pageNum <= this.middleSize+2
// ② 只展示右侧'...',只要当前页码小于或者等于要展示的中间页码时就展示
let pages = [1];
for(let i=2; i<this.middleSize+1; i++) {
pages.push(i);
}
pages.push('...');
pages.push(this.totalNum);
return pages;
}else if(this.pageNum >= this.totalNum - (this.middleSize - 1)) {
// ③ 只展示左侧'...',主要当前页码 大于或等于 总页码-(中间要展示页码的个数 - 1)就展示
let pages = [1, '...'];
for(let i=this.totalNum-this.middleSize+1; i<=this.totalNum; i++) {
pages.push(i);
}
return pages;
}else {
// ④ 展示左右两侧的'...'
let pages = [1, '...'];
// 当左右两侧的...都展示时,中间的页码该如何展示呢?其实就是 当前页码 - (中间要展示页码的个数/2向下取整) 到 当前页码 + (中间要展示页码的个数/2向下取整)即可
const half = Math.floor(this.middleSize/2); // 向下取整
for(let i=this.pageNum-half; i<=this.pageNum+half; i++) {
pages.push(i);
}
pages.push('...');
pages.push(this.totalNum);
return pages;
}
}
},
mounted() {
// 每页展示多少条数据
this.perPageCount = this.page_size[0];
// 计算总页码是多少
this.totalNum = Math.ceil(this.totalCount/parseInt(this.perPageCount));
},
methods: {
// 点击'上一页'、'下一页'
preOrNext(n) {
this.pageNum = this.pageNum + n;
this.pageNum <= 1 ? this.pageNum = 1 : this.pageNum > this.totalNum ? this.pageNum = this.totalNum : null;
// 作为子组件,当前页码发生改变时需要通知父组件
// this.$emit('pageNumChanged', this.pageNum);
},
// 点击'页码'
select(item) {
if(typeof item === 'string') return;
if(item == this.pageNum) return;
this.pageNum = item;
// 作为子组件,当前页码发生改变时需要通知父组件
// this.$emit('pageNumChanged', this.pageNum);
},
// 选择页面展示条数,重新计算总页码
changePerPageCount() {
this.totalNum = Math.ceil(this.totalCount/parseInt(this.perPageCount));
}
}
}
</script> <style lang="scss" type="text/css">
.pageContainer {
display: flex;
justify-content: space-between;
.pageSizeInner {
padding-top: 9px;
.totalCount {
display: inline-block;
margin-right: 5px;
}
.pageSize {
display: inline-block;
>select {
padding: 0 3px;
width: 100px;
height: 30px;
font-size: 12px;
border: 1px solid #eee;
border-radius: 2px;
box-sizing: border-box;
outline: none;
}
}
}
.pagesInner {
display: inline-block;
text-align: center;
font-size: 0;
li {
display: inline-block;
margin: 5px;
list-style: none;
>span {
display: block;
width: 46px;
height: 36px;
line-height: 36px;
text-align: center;
font-size: 12px;
border: 1px solid #eee;
border-radius: 5px;
cursor: pointer;
}
&.noClick {
>span {
cursor: no-drop;
// border-color: transparent;
}
}
&.actived {
>span {
border-color: #2d8cf0;
background-color: #2d8cf0;
color: #fff;
}
}
}
}
}
</style>

(注:记住一个原则就可实现分页,右点左侧页码个数 = middleSize, 左点右侧页码个数 = middleSize,totalNum<=middleSize+2无点只有页码,除以上三种情况外左右两侧...都展示)

用vue写一个分页器代码的更多相关文章

  1. 用ES6的class模仿Vue写一个双向绑定

    原文地址:用ES6的class模仿Vue写一个双向绑定 点击在线尝试一下 最终效果如下: 构造器(constructor) 构造一个TinyVue对象,包含基本的el,data,methods cla ...

  2. 用vue写一个仿简书的轮播图

    原文地址:用vue写一个仿简书的轮播图 先展示最终效果: Vue的理念是以数据驱动视图,所以拒绝通过改变元素的margin-top来实现滚动效果.写好css样式,只需改变每张图片的class即可实现轮 ...

  3. 用vue写一个仿app下拉刷新的组件

    如果你用vue弄移动端的页面,那么下拉刷新还是比较常见的场景,下面来研究如何写一个下拉刷新的组件(先上图); 由于节省大家的时间,样式就不贴出来了. html结构也不必介绍了,直接看代码吧-.- &l ...

  4. 使用Vue写一个九九乘法表

    Vue.js是一套构建用户界面的渐进式框架.与其他重量级框架不同的是,Vue 采用自底向上增量开发的设计. 下面是在Vue 测试实例 - 菜鸟教程(runoob.com)使用Vue写的一个九九乘法表, ...

  5. [Vue]写一个简单的文件上传控件

    ​这篇将介绍如何写一个简单的基于Vue+Element的文件上传控件. 控件将具有 1. 上传队列的列表,显示文件名称,大小等信息,可以显示上传进度实时刷新 2. 取消上传 ​ 使用Element的u ...

  6. 教你用Vue写一个开心消消乐

    之前做过一个算法题,算法要求就是写一个开心消消乐的逻辑算法,当时也是考虑了一段时间才做出来.后来想了想,既然核心算法都有了,能不能实现一个开心消消乐的小游戏呢,于是花了两天时间做了一个小游戏出来. 效 ...

  7. Vue学习—Vue写一个图片轮播组件

    1.先看效果: 熟悉的图片轮播,只要是个网站,百分之90以上会有个图片轮播.我认为使用图片轮播. 第一可以给人以一种美观的感受,而不会显得网站那么呆板, 第二可以增加显示内容,同样的区域可以显示更多内 ...

  8. 使用Vue写一个登陆页面并在管理页面查看和修改

    注册页面代码如下html <!DOCTYPE html> <html lang="en"> <head> <meta charset=&q ...

  9. vue 写一个炫酷的轮播图

    效果如上图: 原理: 1.利用css 的 transform 和一些其他的属性,先选五张将图片位置拍列好,剩余的隐藏 2.利用 js 动态切换类名,达到切换效果 css代码如下 .swiper-cer ...

随机推荐

  1. js内存空间及this关键词详解

    http://mp.weixin.qq.com/s/FYFepXmkzzDYNLKhpovYFA

  2. 03 MySQL之数据类型和运算符

    01-数据类型 MySQL支持多种数据类型,主要有 数值类型.日期/时间类型和字符串类型. 1.1 整数类型 1.2 浮点数类型和定点数类型 单精度浮点类型(FLOAT)和双精度浮点类型 (DOUBL ...

  3. springboot2.0+redis实现消息队列+redis做缓存+mysql

    本博客仅供参考,本人实现没有问题. 1.环境 先安装redis.mysql 2.springboot2.0的项目搭建(请自行完成),本人是maven项目,因此只需配置,获取相应的jar包,配置贴出. ...

  4. 《计算机系统要素》第四章 类汇编语言 Hack

    这章通过学习书中自己设计的Hack语言的使用,弄懂汇编语言的工作原理. 汇编语言最接近底层了,因为每个指令对应一个二进制编码. 当这些指令都变成...0101011100101...的形式后,内存Me ...

  5. What's binary search?

    Binary Search: Search a sorted array by repeatedly  dividing the search interval in half. Begin with ...

  6. XmlEncrypt

    using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; usin ...

  7. linux的vm.overcommit_memory的内存分配参数详解

    公司的redis有时background save db不成功,通过log发现下面的告警,很可能由它引起的: [13223] 17 Mar 13:18:02.207 # WARNING overcom ...

  8. 纹理特征描述之灰度差分统计特征(平均值 对比度 熵) 计算和比较两幅纹理图像的灰度差分统计特征 matlab代码实现

    灰度差分统计特征有: 平均值:​ 对比度:​ 熵:​ i表示某一灰度值,p(i)表示图像取这一灰度值的概率 close all;clear all;clc; % 纹理图像的灰度差分统计特征 J = i ...

  9. C语言递归之翻转二叉树

    题目描述 翻转一棵二叉树. 示例 输入: / \ / \ / \ 输出: / \ / \ / \ 题目要求 /** * Definition for a binary tree node. * str ...

  10. 关于kail的远程连接

    昨天开始学关于网络攻防的一下知识,虚拟机的镜像用的是kail,对自己造成了很多不适应的地方,有点自闭了. 最近会和大家分享一些关于kail的问题或者说网络攻防方面.这次就说一下kail的远程服务. k ...