分页类

这个适用情况:

适用于前端页面已提供分页按钮样式的情况

分页规则:

首页,尾页,上页,下页 这四个按钮必定出现,中间分页动态生成5个

如:首 上 2 3 4 5 6 下 尾

public class Pager {
// public static void main(String args[]){
// Pager p = new Pager();
// String pstr = p.getInitPager(10,200,1);
// System.err.println("pstr="+pstr);
// } // private static int pageSize = 20;
/*
* @method 分页,默认显示5页
* */
public static String getInitPager(int pageSize,int totalCount,int curPage){
curPage = (curPage == 0) ? 1:curPage;
int totalPage = getPageCount(pageSize,totalCount);
int p_pre = (curPage>1) ? curPage-1 : 1;//上一页
int p_next = (curPage<totalCount) ? curPage+1 : totalCount;//下一页 //分页首端 固定部分
StringBuffer frontFixedPage = new StringBuffer();
frontFixedPage.append("<ul class='pagination pull-right'><li><a href='javascript:fn_page(1)'>首</a></li>\n");
frontFixedPage.append("<li><a href='javascript:fn_page("+p_pre+")'>上</a></li>\n");
//分页末尾 固定部分
StringBuffer tailFixedPage = new StringBuffer();
tailFixedPage.append("<li><a href='javascript:fn_page("+p_next+")'>下</a></li>\n");
tailFixedPage.append("<li><a href='javascript:fn_page("+totalPage+")'>尾</a></li>\n");
//分页末尾统计 固定部分
StringBuffer fianlFixedPage = new StringBuffer();
fianlFixedPage.append("<li class='disabled'><a>页次:"+curPage+"/"+totalPage+"页 共"+totalCount+"条</a></li></ul>"); //分页中间 变动部分
StringBuffer midChangePage = new StringBuffer(); if(totalPage <= 5 ){
for(int i = 1; i <= totalPage; i++){
String active = (curPage == i) ? "class='active'" : "";
midChangePage.append("<li "+active+"><a href='javascript:fn_page("+i+")'>"+i+"</a></li>\n");
}
}else{
//页数n>5的,显示页数n-2,n-1,n,n+1,n+2
if(curPage > 2 && curPage <= totalPage - 2){
for(int i = curPage-2; i <= curPage + 2; i++){
String active = (curPage == i) ? "class='active'" : "";
midChangePage.append("<li "+active+"><a href='javascript:fn_page("+i+")'>"+i+"</a></li>\n");
}
}
//当前页<=2的,显示1,2,3,4,5
else if(curPage<=2){
for(int i = 1; i <= 5; i++){
String active = (curPage == i) ? "class='active'" : "";
midChangePage.append("<li "+active+"><a href='javascript:fn_page("+i+")'>"+i+"</a></li>\n");
}
}
//当前页>末尾第二页的,显示n-4,n-3,n-2,n-1,n
else if(curPage > totalPage - 2){
for(int i = totalPage - 4; i <= totalPage; i++){
String active = (curPage == i) ? "class='active'" : "";
midChangePage.append("<li "+active+"><a href='javascript:fn_page("+i+")'>"+i+"</a></li>\n");
}
}
}
StringBuffer pageStr = new StringBuffer();
pageStr.append(frontFixedPage);
pageStr.append(midChangePage);
pageStr.append(tailFixedPage);
pageStr.append(fianlFixedPage); frontFixedPage = null;
midChangePage = null;
tailFixedPage = null;
fianlFixedPage = null;
return pageStr.toString();
}
/*
* @method 计算总页数
* */
public static int getPageCount(int pageSize,int totalCount){
int p = (int)Math.ceil((double)totalCount/pageSize);
p = (p == 0) ? 1 : p;
return p;
} /*<ul class='pagination pull-right'>
<li>
<a href='javascript:fn_page(1)'>首</a></li>
<li>
<a href='javascript:fn_page(1)'>上</a></li>
<li class='active'>
<a href='javascript:'>1</a></li>
<li>
<a href='javascript:fn_page(2)'>2</a></li>
<li>
<a href='javascript:fn_page(3)'>3</a></li>
<li><a href='javascript:fn_page(2)'>下</a></li>
<li><a href='javascript:fn_page(3)'>尾</a></li>
<li class='disabled'>
<a>页次:1/3页 共26条</a>
</li>
</ul>*/
}

java代码分页的更多相关文章

  1. Java代码实现 增删查 + 分页——实习第四天

    今天项目内容已经开始了,并且已经完成好多基本操作,今天就开始总结今天学习到的内容,和我遇到的问题,以及分析这其中的原因. 内容模块: 1:Java代码实现对数据库的增删查: 2:分页且获取页面信息: ...

  2. 亿级别记录的mongodb分页查询java代码实现

    1.准备环境 1.1 mongodb下载 1.2 mongodb启动 C:\mongodb\bin\mongod --dbpath D:\mongodb\data 1.3 可视化mongo工具Robo ...

  3. JAVA 代码开发规范

    一.开发工具规范: 1. 开发工具经项目负责人调试后统一确定. 2. 开发工具一经确定不允许集成任何非统一插件,若有需要,经项目负责人同意后统一为 项目组成员添加. 3. 开发工具的编码格式不允许修改 ...

  4. java 代码

    java 里的 pandas tablesaw DataFrame 再有就是 spark 了 java 代码规范 Java8特性详解 lambda表达式 Stream Sonar 规则检测 sprin ...

  5. Java代码解决ElasticSearch的Result window is too large问题

    调用ElasticSearch做分页查询时报错: QueryPhaseExecutionException[Result window is too large, from + size must b ...

  6. 分享知识-快乐自己:java代码 操作 solr

    POM 文件: <!-- solr客户端 --> <dependency> <groupId>org.apache.solr</groupId> < ...

  7. elasticsearch查询所有数据restful api以及java代码实现

    原文:http://blog.java1234.com/blog/articles/366.html restful api实现如下: get http://192.168.1.111:9200/fi ...

  8. Java和操作系统交互(Java 代码是怎么执行)(转)

    结合 CPU 理解一行 Java 代码是怎么执行的 根据冯·诺依曼思想,计算机采用二进制作为数制基础,必须包含:运算器.控制器.存储设备,以及输入输出设备,如下图所示. 我们先来分析 CPU 的工作原 ...

  9. 操作系统 | 结合 CPU 理解一行 Java 代码是怎么执行的

    根据冯·诺依曼思想,计算机采用二进制作为数制基础,必须包含:运算器.控制器.存储设备,以及输入输出设备,如下图所示. 我们先来分析 CPU 的工作原理,现代 CPU 芯片中大都集成了,控制单元,运算单 ...

随机推荐

  1. 在手机上点击input框时会放大页面

    加上  <meta name="viewport" content="initial-scale=1.0, minimum-scale=1.0, maximum-s ...

  2. 题解 P1184 【高手之在一起】

    好!机会来了! 依评论区的要求,小金羊献上STLset<string>的题解. 当然不会告诉你map<string,bool>我根本不会用 所以,有什么内置的成员函数救救孩子? ...

  3. 【题解】 bzoj1088: [SCOI2005]扫雷Mine (神奇的做法)

    bzoj1088,懒得复制,戳我戳我 Solution: 其实这个有个结论,答案只会有\(0\),\(1\),\(2\)三种(我真的是个弱鸡,这个都想不到) 然后我们假设第一个就可以推出所有的状态(显 ...

  4. 2017年11月GitHub上最热门的Java项目出炉

    2017年11月GitHub上最热门的Java项目出炉~ 一起来看看这些项目你使用过哪些呢? 1分布式 RPC 服务框架 dubbohttps://github.com/alibaba/dubbo S ...

  5. 【BZOJ1304】[CQOI2009]叶子的染色(动态规划)

    [BZOJ1304][CQOI2009]叶子的染色(动态规划) 题面 BZOJ 洛谷 题解 很简单. 设\(f[i][0/1/2]\)表示以\(i\)为根的子树中,还有颜色为\(0/1/2\)(\(2 ...

  6. 【bzoj1040】 ZJOI2008—骑士

    http://www.lydsy.com/JudgeOnline/problem.php?id=1040 (题目链接) 题意 一个基环森林,从中选出不相邻的若干个点使得这些点的点权和最大. Solut ...

  7. web入门之十 JS高级编程基础

    学习内容 JavaScript函数 JavaScript类和对象 解析JSON数据 能力目标 深入了解JavaScript函数 熟悉JavaScript面向对象编程 熟练进行JSON数据解析 本章简介 ...

  8. 8.30 牛客OI赛制测试赛1 F题 子序列

    题目描述 给出一个长度为n的序列,你需要计算出所有长度为k的子序列中,除最大最小数之外所有数的乘积相乘的结果 输入描述: 第一行一个整数T,表示数据组数.对于每组数据,第一行两个整数N,k,含义如题所 ...

  9. C++并发编程实战---阅读笔记

    1. 当把函数对象传入到线程构造函数中时,需要避免“最令人头痛的语法解析”.如果传递了一个临时变量,而不是一个命名的变量:C++编译器会将其解析为函数声明,而不是类型对象的定义. 例如: class ...

  10. C++外观模式和组合模式

    外观模式应该是用的很多的一种模式,特别是当一个系统很复杂时,系统提供给客户的是一个简单的对外接口,而把里面复杂的结构都封装了起来.客户只需使用这些简单接口就能使用这个系统,而不需要关注内部复杂的结构. ...