java代码分页
分页类
这个适用情况:
适用于前端页面已提供分页按钮样式的情况
分页规则:
首页,尾页,上页,下页 这四个按钮必定出现,中间分页动态生成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代码分页的更多相关文章
- Java代码实现 增删查 + 分页——实习第四天
今天项目内容已经开始了,并且已经完成好多基本操作,今天就开始总结今天学习到的内容,和我遇到的问题,以及分析这其中的原因. 内容模块: 1:Java代码实现对数据库的增删查: 2:分页且获取页面信息: ...
- 亿级别记录的mongodb分页查询java代码实现
1.准备环境 1.1 mongodb下载 1.2 mongodb启动 C:\mongodb\bin\mongod --dbpath D:\mongodb\data 1.3 可视化mongo工具Robo ...
- JAVA 代码开发规范
一.开发工具规范: 1. 开发工具经项目负责人调试后统一确定. 2. 开发工具一经确定不允许集成任何非统一插件,若有需要,经项目负责人同意后统一为 项目组成员添加. 3. 开发工具的编码格式不允许修改 ...
- java 代码
java 里的 pandas tablesaw DataFrame 再有就是 spark 了 java 代码规范 Java8特性详解 lambda表达式 Stream Sonar 规则检测 sprin ...
- Java代码解决ElasticSearch的Result window is too large问题
调用ElasticSearch做分页查询时报错: QueryPhaseExecutionException[Result window is too large, from + size must b ...
- 分享知识-快乐自己:java代码 操作 solr
POM 文件: <!-- solr客户端 --> <dependency> <groupId>org.apache.solr</groupId> < ...
- elasticsearch查询所有数据restful api以及java代码实现
原文:http://blog.java1234.com/blog/articles/366.html restful api实现如下: get http://192.168.1.111:9200/fi ...
- Java和操作系统交互(Java 代码是怎么执行)(转)
结合 CPU 理解一行 Java 代码是怎么执行的 根据冯·诺依曼思想,计算机采用二进制作为数制基础,必须包含:运算器.控制器.存储设备,以及输入输出设备,如下图所示. 我们先来分析 CPU 的工作原 ...
- 操作系统 | 结合 CPU 理解一行 Java 代码是怎么执行的
根据冯·诺依曼思想,计算机采用二进制作为数制基础,必须包含:运算器.控制器.存储设备,以及输入输出设备,如下图所示. 我们先来分析 CPU 的工作原理,现代 CPU 芯片中大都集成了,控制单元,运算单 ...
随机推荐
- 【Webpack2.X笔记】 配合react项目进行配置
前言: 本文是自己在工作中使用webpack进行react开发项目构建的一些经验总结,做以记录防范后续踩坑. 如果您还没有webpack相关基础,请先移步 入门Webpack,看这篇就够了 进行基础学 ...
- Luogu2257 YY的GCD/BZOJ2818 Gcd加强版(莫比乌斯反演+线性筛)
一通套路之后得到 求出中间那个函数的前缀和的话就可以整除分块了. 暴力求的话复杂度其实很优秀了,大约在n~nlogn之间. 不过可以线性筛做到严格线性.考虑其最小质因子,如果是平方因子那么只有其有贡献 ...
- MT【200】一道自招的不等式
(2018武汉大学自招)设$x,y,z\ge0,xy+yz+zx=1$证明:$\dfrac{1}{x+y}+\dfrac{1}{y+z}+\dfrac{1}{z+x}\ge \dfrac{5}{2}$ ...
- 【刷题】LOJ 6013 「网络流 24 题」负载平衡
题目描述 G 公司有 \(n\) 个沿铁路运输线环形排列的仓库,每个仓库存储的货物数量不等.如何用最少搬运量可以使 \(n\) 个仓库的库存数量相同.搬运货物时,只能在相邻的仓库之间搬运. 输入格式 ...
- 算法-动态规划DP小记
算法-动态规划DP小记 动态规划算法是一种比较灵活的算法,针对具体的问题要具体分析,其宗旨就是要找出要解决问题的状态,然后逆向转化为求解子问题,最终回到已知的初始态,然后再顺序累计各个子问题的解从而得 ...
- 【洛谷P1991】无线通讯网
题目大意:给定一个 N 个顶点的完全图,边有边权,现在要求使得图中所有顶点联通的情况下,第 M-1 大的边最小值是多少. 题解:所有点联通的最小要求是所有点和连接这些点的边构成原图的一棵生成树,那么问 ...
- Java Try-with-resources
目录 资源管理与 Try-Catch-Finally,旧风格 Try-with-resources 管理多个资源 自定义 AutoClosable 实现 Try-with-resources 是 ja ...
- jQueryCDN
分享几个jquery的几个国内国外的CDN加速节点,方便广大的开发设计者调用和节约空间,官网的总是最新版本的jquery所以不用去担心版本更新问题,其他加速节点可能不会在更新版本,所以取舍问题自己决定 ...
- python的面向对象-实例(对象)的相关知识、实例化
1.对象就是实例,什么是实例 类运行的过程就是实例化的过程,实例化产生的结果就是产生了一个实例 class的牛逼之处就是不用手动的return,他会加载完函数之后,自动return __init__ ...
- UnicodeDecodeError gbk codec can't decode byte in position illegal multibyte sequence
UnicodeDecodeError:'gbk' codec can't decode byte in position : illegal multibyte sequence 觉得有用的话,欢迎一 ...