随笔的一个记录。
有两个参考类,
import java.util.List;
/**
* 分页显示对象
* @param <T>
*/
public class PageView<T> {
/** 分页数据 **/
private List<T> records;
/** 页码开始索引和结束索引 **/
private PageIndex pageindex;
/** 总页数 **/
private long totalpage = 1;
/** 每页显示记录数 **/
private int maxresult = 12;
/** 当前页 **/
private int currentpage = 1;
/** 总记录数 **/
private long totalrecord;
/** 页码数量 **/
private int pagecode = 10;
/** 要获取记录的开始索引 **/
public int getFirstResult() {
return (this.currentpage-1) * this.maxresult;
}
public int getPagecode() {
return pagecode;
}
public void setPagecode(int pagecode) {
this.pagecode = pagecode;
}
public PageView(int maxresult, int currentpage) {
this.maxresult = maxresult;
this.currentpage = currentpage;
}
public void setQueryResult(QueryResult<T> qr){
setTotalrecord(qr.getTotal());
setRecords(qr.getResultList());
}
public long getTotalrecord() {
return totalrecord;
}
public void setTotalrecord(long totalrecord) {
this.totalrecord = totalrecord;
setTotalpage(this.totalrecord % this.maxresult == 0 ? this.totalrecord / this.maxresult : this.totalrecord / this.maxresult + 1);
}
public List<T> getRecords() {
return records;
}
public void setRecords(List<T> records) {
this.records = records;
}
public PageIndex getPageindex() {
return pageindex;
}
public long getTotalpage() {
return totalpage;
}
public void setTotalpage(long totalpage) {
this.totalpage = totalpage;
this.pageindex = PageIndex.getPageIndex(pagecode, currentpage, totalpage);
}
/**
* 每页显示记录数
* @return
*/
public int getMaxresult() {
return maxresult;
}
public int getCurrentpage() {
return currentpage;
}
}
另外一个
/**
* 算出页码的开始索引和结束索引
*/
public class PageIndex {
/** 开始索引 */
private long startindex;
/** 结束索引 */
private long endindex;
public PageIndex(long startindex, long endindex) {
this.startindex = startindex;
this.endindex = endindex;
}
public long getStartindex() {
return startindex;
}
public void setStartindex(long startindex) {
this.startindex = startindex;
}
public long getEndindex() {
return endindex;
}
public void setEndindex(long endindex) {
this.endindex = endindex;
}
/**
* 算出页码的开始索引和结束索引
* @param viewpagecount 页码数量
* @param currentPage 当前页数
* @param totalpage 总页数
* @return
*/
public static PageIndex getPageIndex(long viewpagecount, int currentPage, long totalpage){
long startpage = currentPage - (viewpagecount % 2 == 0 ? viewpagecount / 2 - 1 : viewpagecount / 2);
long endpage = currentPage + viewpagecount / 2;
if(startpage < 1){
startpage = 1;
if(totalpage >= viewpagecount) endpage = viewpagecount;
else endpage = totalpage;
}
if(endpage > totalpage){
endpage = totalpage;
if((endpage - viewpagecount)> 0) startpage = endpage - viewpagecount + 1;
else startpage = 1;
}
return new PageIndex(startpage, endpage);
}
下面是Freemarker的分页宏
<#-- 总页数,当前页 -->
<#macro pagination pageView>
<div class="pages">
<label>共${pageView.totalpage}页,约${pageView.totalrecord}条数据</label>
<#if pageView.currentpage != 1>
<a href="javascript:pageinationView(1)" title="首页" class="nav"><span>首页</span></a>
<a href="javascript:pageinationView(${pageView.currentpage - 1})" title="上一页" class="nav"><span>上一页</span></a>
<#else>
<span>首页</span>
<span>上一页</span>
</#if>
<#list pageView.pageindex.startindex..pageView.pageindex.endindex as index>
<#if pageView.currentpage == index>
<a href="#" class="current">${index}</a>
<#else>
<a href="javascript:pageinationView(${index})" title="第${index}页" >${index}</a>
</#if>
</#list>
<#if pageView.currentpage != pageView.totalpage>
<a href="javascript:pageinationView(${pageView.currentpage + 1})" title="下一页" class="nav"><span>下一页</span></a>
<a href="javascript:pageinationView(${pageView.totalpage})" title="未页" class="nav"><span>未页</span></a>
<#else>
<span>下一页</span>
<span>未页</span>
</#if>
</div>
<script type="text/javascript">
function pageinationView(pageNum) {
document.getElementById("pageNum").value=pageNum;
document.getElementById("pageinationForm").submit();
}
</script>
</#macro>
页面的引用
<!--分页 -->
<form id="pageinationForm" method="post" action="clazz-list">
<input type="hidden" id="pageNum" name="pageNum" value="${pageNum}" />
</form>
<#import "*/main/main-page.ftl" as pager>
<@pager.pagination pageView=pageView/>
<!-- 分页 -->
现在应该出来了基本的分页。等后续的工作完成再记录!
分享到:
相关推荐
freemarker分页,freemarker分页,freemarker分页
这是FreeMarker通用的分页
好用的 freemarker 分页宏模板dom结构比较主流的一个分页一排显示10个分页按钮(想定制的话把页码提取出来做为参数即可)pagenav.previousPage 存着上一页pagenav.totalPage 总页数pagenav.pageNo 当前页面页码page...
一个用FTL定义的非常通用数据分页指令,有源码,有使用示例。使用效果图可以参看本人博客中的相关文章:http://blog.csdn.net/qjyong/archive/2009/10/18/4693142.aspx
freemarker结合struts2分页,在后台接收当前页和每页显示条数即可,其他可按照需求自行更改
NULL 博文链接:https://asialee.iteye.com/blog/2062313
freemarker的分页.数据库是mysql.
NULL 博文链接:https://cjb.iteye.com/blog/403878
学习freemarker后 发现网上用宏实现分页的例子几乎没有,所以自己写了个。
主要就是用servlet做的,freemarker和httpclient的静态化都封装好了工具类了,简单,有文档,可以看懂
Spring,Spring Data Jpa,freemarker,bootstrap实现的分页源代码
NULL 博文链接:https://fenyouze.iteye.com/blog/440826
不过由于小弟资历浅薄,也没心思看,主要是strut2的标签本来我就觉得不大习惯,另外上个月接触了freemarker后,实在是用的爽死了,为什么不用freemarker的macro指令写个通用的分页呢?马上想到模仿TX的...
使用FreeMarker配合Servlet写了一个分页程序,使用环境是Java7和Tomcat7,Eclipse 4.2,程序比较简单,并且加了注释,应该算是清楚易懂吧,适合初学者(我本身也是初学者),有问题私信可以再和大家讨论。
留言板的静态页面是从网上找的,,分页自己写的,不一定很严谨,我只是凑合用的,注释的话好像只有分页有点,里面有jar包,导入myeclipse就可以了。还有mysql的sql文件,同样导入mysql即可。
多数据源部分代码,直接运行beta\src\main\java\org\springframework\jdbc\datasource\lookup下Test的main方法,可根据业务开放接口
Spring4 SpringMVC4 Hibernate4 Freemarker Bootstrap3 整合的小DEMO,主要就是一个登录页面,加一个主页面,然后实现增删改查,还有分页的功能 说明:在项目的doc下有数据库文件,新建数据库名为 db_shf,编码设为...
利用freemarker 模板生成pdf ,利用easypoi 生成excel(带图片,水印,分页)
SpringBoot+SSM框架+freemarker+Druid数据源+MySQL+分页,整个采用SpringBoot框架,数据库是MySQL的5.5.X版本,如果是8.0的换pom的mysql依赖包和驱动,阿里推出的Druid数据源配置,访问项目后面加/druid进入druid的...