最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

JavaScript趣题:前端分页

来源:动视网 责编:小采 时间:2020-11-27 20:26:05
文档

JavaScript趣题:前端分页

JavaScript趣题:前端分页:在前端进行分页是一件很炫酷的事情,它可以缓解服务器端的压力,减少了请求次数以及服务器计算量。不过,你得需要把它做成一个组件的形式,这样才方便在各处调用,否则每一个页面都写一套,岂不是费力不讨好?最好是实现一个这样的帮助类,如下所示://第一个
推荐度:
导读JavaScript趣题:前端分页:在前端进行分页是一件很炫酷的事情,它可以缓解服务器端的压力,减少了请求次数以及服务器计算量。不过,你得需要把它做成一个组件的形式,这样才方便在各处调用,否则每一个页面都写一套,岂不是费力不讨好?最好是实现一个这样的帮助类,如下所示://第一个


在前端进行分页是一件很炫酷的事情,它可以缓解服务器端的压力,减少了请求次数以及服务器计算量。

不过,你得需要把它做成一个组件的形式,这样才方便在各处调用,否则每一个页面都写一套,岂不是费力不讨好?

最好是实现一个这样的帮助类,如下所示:

//第一个参数是要分页的JSON对象 
//第二个参数是每一页的最大项数 
var helper = new PaginationHelper(['a','b','c','d','e','f'], 4); 
//总共多少页 => Math.ceil(6 / 4) 
helper.pageCount(); // 2 
//总共多少项 => array.length 
helper.itemCount(); // 6 
//求当前页的项数,这个页的索引是从0开始的 
helper.pageItemCount(0); // 4 
//6 - 4 = 2 
helper.pageItemCount(1); // 2 
//总共才2页,所以当前页无效,返回-1 
helper.pageItemCount(2); // -1 
 
//当前索引是属于第几页? 
helper.pageIndex(5); // 1 
helper.pageIndex(2); // 0 
//总共都才6条记录,所以20无效 
helper.pageIndex(20); // -1 
//索引小于0,无效返回-1 
helper.pageIndex(-10); // -1

无论是前端分页还是后端分页,思路是一样的,都比较简单,不过得注意对非法值的处理。

function PaginationHelper(collection, itemsPerPage){ 
 this.collection = collection; 
 this.itemsPerPage = itemsPerPage; 
} 
 
PaginationHelper.prototype.itemCount = function() { 
 return this.collection.length; 
} 
 
PaginationHelper.prototype.pageCount = function() { 
 return Math.ceil(this.itemCount() / this.itemsPerPage); 
} 
 
PaginationHelper.prototype.pageItemCount = function(pageIndex) { 
 if(pageIndex < this.pageCount() - 1){ 
 return this.itemsPerPage; 
 } 
 else if(pageIndex == this.pageCount() - 1){ 
 return this.itemCount() - pageIndex * this.itemsPerPage; 
 } 
 else{ 
 return -1; 
 } 
} 
 
PaginationHelper.prototype.pageIndex = function(itemIndex) { 
 if(itemIndex >=0 && itemIndex < this.itemCount()){ 
 return Math.floor(itemIndex / this.itemsPerPage); 
 } 
 return -1; 
}

文档

JavaScript趣题:前端分页

JavaScript趣题:前端分页:在前端进行分页是一件很炫酷的事情,它可以缓解服务器端的压力,减少了请求次数以及服务器计算量。不过,你得需要把它做成一个组件的形式,这样才方便在各处调用,否则每一个页面都写一套,岂不是费力不讨好?最好是实现一个这样的帮助类,如下所示://第一个
推荐度:
标签: js javascript 分页
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top