服务器之家

服务器之家 > 正文

html+vue.js 实现漂亮分页功能可兼容IE

时间:2021-11-08 15:38     来源/作者:echoyya

当功能比较简单,在单一html中使用vue.js分页展示数据,并未安装脚手架,或使用相关ui框架,此时需要手写一个分页器,不失为最合理最便捷的解决方案

先看一下实现效果:

 html+vue.js 实现漂亮分页功能可兼容IE

 上代码:

1.简单搞一搞 css,此处代码有折叠
2.简单搞一搞 html 

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
<div id="app" v-cloak @click="showoption=false">
 第{{pageindex}}页, 每页显示{{pagesize}}条
 <div v-show="pagetotalnum > 1" class="pagecontainer">
  共{{datalistlength}}条
 <ul class="pagesinner">
  <li class="page" @click="prevornext(-1)"><span aria-hidden="true">&lt;</span></li>
  <li class="page" v-for="(item, index) in pages" :key="index" :class="{actived: item == pageindex}" @click="selectpage(item)">
  <span>{{item}}</span>
  </li>
  <li class="page" @click="prevornext(1)"><span class="fa fa-chevron-right" aria-hidden="true">&gt;</span></li>
 </ul>
 <div class="page-size-box">
  <span @click.stop="showoption=!showoption">{{pagesize}}条/页</span>
  <ul class="size-option" v-show="showoption">
  <li v-for="(item, index) in pagesizelist" :key="index" @click="pagesize=item;showoption=false">{{item}}条/页</li>
  </ul>
 </div>
 跳至&nbsp;
  <form id="frm1">
   <input type="text" v-model="gotopage" style="text-align: center;">
  </form>
 &nbsp;页&nbsp;
 button @click="handlegotopage">确定</button>
 </div>
</div>

 3.搞事情啦 ~~~~

首先分析一下分页功能的实现思路:

  • 首页和尾页始终显示,

  • 通过数据总条数datalistlength及每页显示条数pagesize,计算出总页数pagetotalnum

  • 监听watch一下,每页显示条数pagesize,重置当前页码pageindex=1

  • 我设计的分页每次最多显示5个页码(大家可根据需求自行调整),剩余部分 ... 代替,并设置不可点击,

  • 根据不同的总页数和当前页码的切换,页签展示形态有所不同,展示形态如下图对应序号展示

总页数 <= 1,不显示分页器
总页数 <= 5 && 总页数 > 1,显示全部页码
总页数 > 5 && 当前页面 <= 3 , 倒数第二个页码为...,页码从左往右计算
总页数 > 5 && 当前页面 > 3 && 当前页 < 总页数 - 3 , 正倒数第二个页码都为..., 页码以当前页码计算,±1
总页数 > 5 && 当前页面 > 3 && 当前页 > 总页数 - 3 , 正数第二个页码为..., 页码从右往左计算

html+vue.js 实现漂亮分页功能可兼容IE

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
<script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
<script src="https://cdn.polyfill.io/v2/polyfill.min.js"></script>  <!--兼容ie -->
<script>
 var app = new vue({
 el: "#app",
 data: {
  pageindex: 1,
  gotopage: '',
  // pagetotalnum: 16,
  datalistlength:147,
  pagesize:20,
  pagesizelist:[20,30,50,100],
  showoption:false
 },
 methods: {
  prevornext: function(n) {
  this.pageindex += n
  this.pageindex <= 1 ? this.pageindex = 1 : this.pageindex > this.pagetotalnum ? this.pageindex = this.pagetotalnum : null
  },
  selectpage: function(n) {
  if (n === this.pageindex) return
  if (typeof n === 'string') return
  this.pageindex = n
  },
  handlegotopage: function() {
  this.pageindex = this.gotopage <= 1 ? 1 : this.gotopage - 0 >= this.pagetotalnum - 0 ? this.pagetotalnum :
  this.gotopage
  this.gotopage = this.pageindex
  },
 },
 computed: {
  pagetotalnum:function(){
  return this.datalistlength % this.pagesize == 0 ? this.datalistlength / this.pagesize : math.floor(this.datalistlength / this.pagesize) + 1
  },
  pages: function () {
  // 每次最多显示5个页码
  var c = this.pageindex
  var t = this.pagetotalnum
  var p = []
  for (var i = 1; i <= t; i++) {
   p.push(i)
  }
  var l = p.length
  if (l <= 5) { // 总页数<=5,显示全部页码
   return p
  } else if (l > 5 && c <= 3) { // 总页数>5 && 当前页面<=3
   return [1, 2, 3, 4, '...', t]
  } else if (l > 5 && c > 3 && c <= l - 2) { // 总页数 > 5 && 当前页面 > 3 && 当前页 < 总页数 - 3
   return [1, '...', c - 2, c - 1, c, '...', t]
  } else { // 总页数 > 5 && 当前页面 > 3 && 当前页 > 总页数 - 3
   return [1, '...', t - 3, t - 2, t - 1, t]
  }
  },
 },
 watch:{
  pagesize:function(nv,ov){
  this.pageindex = 1
  }
 }
 });
</script>

到此这篇关于html+vue.js 实现漂亮分页功能可兼容ie的文章就介绍到这了,更多相关vue.js 分页内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://www.cnblogs.com/echoyya/p/13937750.html

标签:

相关文章

热门资讯

yue是什么意思 网络流行语yue了是什么梗
yue是什么意思 网络流行语yue了是什么梗 2020-10-11
2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全
2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全 2019-12-26
背刺什么意思 网络词语背刺是什么梗
背刺什么意思 网络词语背刺是什么梗 2020-05-22
2021年耽改剧名单 2021要播出的59部耽改剧列表
2021年耽改剧名单 2021要播出的59部耽改剧列表 2021-03-05
苹果12mini价格表官网报价 iPhone12mini全版本价格汇总
苹果12mini价格表官网报价 iPhone12mini全版本价格汇总 2020-11-13
返回顶部