jsp分页技术
1、以下为分页类:
import java.io.Serializable;
import java.util.List;
import org.apache.commons.lang.builder.ToStringBuilder;
import org.apache.commons.lang.builder.ToStringStyle;
public class ResultFilter<T> implements Serializable{
private static final long serialVersionUID = 5472321653620726832L;
private final static int DEFAULT_NAVIGATOR_SIZE = 5;
//当前页
private int currentPage = 1;
//每页显示数量
private int pageSize = 5;
//总条数
private int totalCount;
private boolean havaNextPage;
private boolean havePrePage;
private int navigatorSize;
//存放查询结果用的list
private List<T> items;
public ResultFilter(){
}
public ResultFilter(int totalCount, int pageSize, int currentPage) {
this(totalCount, pageSize, currentPage, DEFAULT_NAVIGATOR_SIZE);
}
public ResultFilter(int totalCount, int pageSize, int currentPage,
int navigatorSize) {
this.totalCount = totalCount;
this.pageSize = pageSize;
this.currentPage = currentPage;
this.navigatorSize = navigatorSize;
}
public int getPageCount() {
int pageCount = 0;
if (pageSize != 0) {
pageCount = totalCount / pageSize;
if (totalCount % pageSize != 0)
pageCount++;
}
return pageCount;
}
public int getCurrentPage() {
currentPage = currentPage < getPageCount() ? currentPage :
getPageCount();
currentPage = currentPage < 1 ? 1 : currentPage;
return currentPage;
}
public int getPageSize() {
return pageSize;
}
public int getTotalCount() {
return totalCount;
}
public boolean isHaveNextPage() {
havaNextPage = false;
if ((getPageCount() > 1) && (getPageCount() > getCurrentPage()))
havaNextPage = true;
return havaNextPage;
}
public boolean isHavePrePage() {
havePrePage = false;
if ((getPageCount() > 1) && (currentPage > 1))
havePrePage = true;
return havePrePage;
}
private int getNavigatorIndex(boolean isBegin) {
int beginNavigatorIndex = getCurrentPage() - navigatorSize / 2;
int endNavigatorIndex = getCurrentPage() + navigatorSize / 2;
beginNavigatorIndex = beginNavigatorIndex < 1 ? 1 : beginNavigatorIndex;
endNavigatorIndex = endNavigatorIndex < getPageCount() ?
endNavigatorIndex :
getPageCount();
while ((endNavigatorIndex - beginNavigatorIndex) < navigatorSize &&
(beginNavigatorIndex != 1 || endNavigatorIndex != getPageCount())) {
if (beginNavigatorIndex > 1)
beginNavigatorIndex--;
else if (endNavigatorIndex < getPageCount())
endNavigatorIndex++;
}
if(isBegin)
return beginNavigatorIndex;
else
return endNavigatorIndex;
}
public int getBeginNavigatorIndex() {
return getNavigatorIndex(true);
}
public int getEndNavigatorIndex() {
return getNavigatorIndex(false);
}
public List<T> getItems() {
return items;
}
public void setItems(List<T> items) {
this.items = items;
}
public void setCurrentPage(int currentPage) {
this.currentPage = currentPage;
}
public void setPageSize(int pageSize) {
this.pageSize = pageSize;
}
public void setTotalCount(int totalCount) {
this.totalCount = totalCount;
}
@Override
public String toString() {
return ToStringBuilder.reflectionToString(this, ToStringStyle.MULTI_LINE_STYLE);
}
}
2、在spring的controller中调用分页类:
@RequestMapping(value="/xxxList") //xxxList.jsp对应的controller
public ModelAndView xxxList(@ModelAttribute ResultFilter<xxx> rf){
systemService.listServiceAll(rf); //调用步骤3 ,分页获取xxx对象
return new ModelAndView("路径/xxxList", "rf", rf); //此处跳转到步骤5所表示的网页,并传递分页参数rf,其中“路径/xxxList”
//表示对应的jsp网页,比如myBook/bookList表示myBook目录下的bookList.jsp
}
3、连操作数据库的service层 获取全部service
@Transactional(readOnly = false)
public void listServiceAll(ResultFilter<Services> rf){
int count=getServiceList().size();
rf.setTotalCount(count);
rf.setItems(serviceDao.getListForPage("from Services", (rf.getCurrentPage() - 1 )* rf.getPageSize(), rf.getPageSize()));
//调用步骤4,分页查询数据库
}
4、
// -------------- 分页QL Query --------------//
@SuppressWarnings("unchecked")
public List<T> getListForPage(String hql,int begin,int num){
Query query = getSession().createQuery(hql);
return query.setFirstResult(begin).setMaxResults(num).list();
}
5、路径/xxxList 对应的jsp网页(注意第四行)
<%@ page language="java" contentType="text/html; charset=utf-8"
pageEncoding="utf-8"%>
<%@ include file="/WEB-INF/views/include/taglib.jsp"%>
<%@ taglib uri="my-taglib" prefix="my"%> <!--使用了自定义标签,该标签在步骤6中定义-->
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>XXXList</title>
</head>
<body>
<form>
<table id="contentTable" >
<tbody>
<c:url value="/xxxDetail" var="url1"></c:url>
<c:url value="/xxxList" var="url1"></c:url> <!--该jsp对应的controller-->
<tr><c:forEach items="${rf.items}" var="xxx">
<td valign="top" style="width:229px;oveflow:hidden;">
<table>
<tr><td ><a name="click to check the detail" href="${url1}?xxxId=${xxx.id}"><img src="${ctxStatic}/images/123.jpg"></img></a></td></tr>
<tr><td >${xxx.attribute1}</td></tr>
<tr><td >${xxx.attribute2}</td></tr>
</table>
</td>
</c:forEach>
</tr>
</tbody>
</table>
<div style="padding-top:30px;"></div>
<my:paging curr="${rf.currentPage}" total="${rf.pageCount}" size="${rf.pageSize}" href="${url2}"/> <!--使用了自定义标签-->
</form>
</body>
</html>
6、自定义标签‘my’
<?xml version="1.0" encoding="UTF-8"?>
<taglib xmlns="http://java.sun.com/xml/ns/j2ee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-jsptaglibrary_2_0.xsd"
version="2.0">
<description>My Tag Library</description>
<tlib-version>1.0</tlib-version>
<short-name>my</short-name>
<uri>my-taglib</uri>
<tag>
<description>split page</description>
<name>paging</name>
<tag-class>aaa.bbb.ccc.PagingTag</tag-class> <!--用到了步骤7中的PagingTag类 ,aaa.bbb.ccc是PagingTag的路径-->
<body-content>empty</body-content>
<attribute>
<description>base href</description>
<name>href</name>
<required>false</required>
<rtexprvalue>true</rtexprvalue>
</attribute>
<attribute>
<description>curr page</description>
<name>curr</name>
<required>true</required>
<rtexprvalue>true</rtexprvalue>
</attribute>
<attribute>
<description>page size</description>
<name>size</name>
<required>true</required>
<rtexprvalue>true</rtexprvalue>
</attribute>
<attribute>
<description>total page</description>
<name>total</name>
<required>true</required>
<rtexprvalue>true</rtexprvalue>
</attribute>
<attribute>
<description>curr parameter name</description>
<name>cparam</name>
<required>false</required>
<rtexprvalue>false</rtexprvalue>
</attribute>
<attribute>
<description>page size parameter name</description>
<name>sparam</name>
<required>false</required>
<rtexprvalue>false</rtexprvalue>
</attribute>
<dynamic-attributes>false</dynamic-attributes>
</tag>
<tag>
<description>front split page</description>
<name>frontPaging</name>
<tag-class>com.aspire.cms.demo.framework.tag.FrontPagingTag</tag-class>
<body-content>empty</body-content>
<attribute>
<description>base href</description>
<name>href</name>
<required>false</required>
<rtexprvalue>true</rtexprvalue>
</attribute>
<attribute>
<description>result filter</description>
<name>rf</name>
<required>true</required>
<rtexprvalue>true</rtexprvalue>
</attribute>
<dynamic-attributes>false</dynamic-attributes>
</tag>
</taglib>
7、自定义标签类
package aaa.bbb.ccc;
import java.io.IOException;
import javax.servlet.jsp.JspException;
import javax.servlet.jsp.JspWriter;
import javax.servlet.jsp.tagext.SimpleTagSupport;
import org.apache.commons.lang.StringUtils;
public class PagingTag extends SimpleTagSupport {
private String href;
//当前页
private String cparam;
//每页条数
private String sparam;
private int curr;//当前页
private int size;//每页条数
private int total;//总页数
@Override
public void doTag() throws JspException, IOException {
JspWriter out = getJspContext().getOut();
if(StringUtils.isEmpty(cparam)) {
cparam = "currentPage";
}
if(StringUtils.isEmpty(sparam)) {
sparam = "pageSize";
}
if(!href.endsWith("?") && !href.endsWith("&")) {
if(href.indexOf("?") == -1) {
href = href + "?";
} else {
href = href + "&";
}
}
if (curr <= 0) {
curr = 1;
} else if (curr > total) {
curr = total;
}
out.append("<span>");
// 首页
if (curr == 1) {
out.append("首页");
} else {
href(out, href, 1, "首页");
}
out.append(" | ");
// 上一页
if (curr == 1) {
out.append("上一页");
} else {
href(out, href, curr - 1, "上一页");
}
out.append(" | ");
// 下一页
if (curr == total) {
out.append("下一页");
} else {
href(out, href, curr + 1, "下一页");
}
out.append(" | ");
// 末页
if (curr == total) {
out.append("末页");
} else {
href(out, href, total, "末页");
}
out.append("</span>");
out.append("<span>第");
out.append(curr + "/" + total);
out.append("页</span>");
super.doTag();
}
private void href(JspWriter out, String href, int curr, String title) throws IOException {
out.append("<a href=\"").append(href).append(cparam).append("=").append("" + curr).append("&").append(sparam).append("=").append("" + size).append("\">").append(title).append("</a>");
}
public int getCurr() {
return curr;
}
public void setCurr(int curr) {
this.curr = curr;
}
public int getTotal() {
return total;
}
public void setTotal(int total) {
this.total = total;
}
public String getHref() {
return href;
}
public void setHref(String href) {
this.href = href;
}
public String getCparam() {
return cparam;
}
public void setCparam(String cparam) {
this.cparam = cparam;
}
public String getSparam() {
return sparam;
}
public void setSparam(String sparam) {
this.sparam = sparam;
}
public int getSize() {
return size;
}
public void setSize(int size) {
this.size = size;
}
}
jsp分页技术的更多相关文章
- JSP分页技术的实现(利用当前页进行前后加减,并利用href进行当前页面传值,传值当然是那个当前值变量)
一.可滚动结果集 Connection con = DriverManager.getConnection(); PreparedStatement stmt = con.prepareStat ...
- 眼下最好的JSP分页技术
2005-08-24 来源:CSDN 作者:wanchao2001 前言 在使用数据库的过程中,不可避免的须要使用到分页的功能,但是JDBC的规范对此却没有非常好的解决.对于这个需求非 ...
- jsp-------------之分页技术(一)
jsp分页技术之: 如下图:百度的喵 看上图中卡哇伊的小苗的爪子下面的数字,就是分页啦!那我们如何做出这样一个效果呢? 下面我们来逐一分解: jsp分页技术一 : (算法) /* int pageS ...
- JSP的分页技术
在实际应用中,如果从数据库中查询的记录特别的多,甚至超过了显示屏的显示范围,这个时候可将结果进行分页显示. 假设总记录数为intRowCount,每页显示的数量为inPageSize,总页数为intP ...
- Javaweb 第15天 web练习和分页技术
第15天 web练习和分页技术 复习day14内容: 学习新技术的思路? 分析功能的思路? 使用queryRunner操作数据库的步骤? ResultSetHandler接口常用实现类(三个重点)? ...
- Jsp分页的简单制作
Jsp分页的简单制作 运行环境:jsp+tomcat+eclipse 技术:servlet+jsp+mysql 分页技术还区分两个:假分页和真分页 假分页:一次性从数据库读出表的所有数据一次性的返回给 ...
- 改进Spring中的分页技术
Spring中有一个PagedListHolder,能够实现分页. 但此类有几个缺点: 1. 使用此类的代码比較繁琐 2. 此类存放的数据源是全部的记录集,即对于记录数为1000条的数据,即使我们仅仅 ...
- JAVAEE之-----MySQL分页技术(带搜索)
需求: 为什么须要採用分页技术呢?在数据库中我们查询数据的时候,须要将数据返回到显示页面.数据库中含有大量数据,所有显示在一个页面过于太多,所以我们须要採用分页技术.每一页显示不同数据. 主要解决这个 ...
- Mysql学习总结(32)——MySQL分页技术详解
1.什么是数据分页:数据分页就是将很多条记录像书本一样分页,每页显示多少行记录: 2.为什么要数据分页:当我们进行sql语句查询时,假如数据有成千上万行记录,如果在同一个页面去显示,那这个页面得有多大 ...
随机推荐
- C# FileSystemWatcher 监视磁盘文件变更
简化需求:有一个简化了的需求是这样的:有一个拍照程序在运行,一旦抓拍之后则将图片文件存储至某目录,然后图片要上传至远程服务器并update数据库. 原需求:原先的需求是这样的:有一台PDA扫码枪,一个 ...
- kvm安装及配置
yum install kvm libvirt python-virtinst qemu-kvm virt-viewer bridge-utils virt-install 修改网卡信息 /etc/ ...
- Linux下载jdk ,Linux如何下载jdk
Linux下载jdk Linux如何下载jdk >>>>>>>>>>>>>>>>>>> ...
- 第二篇:杂项之图像处理pillow
杂项之图像处理pillow 杂项之图像处理pillow 本节内容 参考文献 生成验证码源码 一些小例子 1. 参考文献 http://pillow-cn.readthedocs.io/zh_CN/ ...
- asp.net mvc+web api+easyui
前奏:第一次写博客,记录一下学习和开发的过程. 现在写的是一个后台管理系统,有基本的权限功能,其他功能都可以扩展.用到的技术是 asp.net mvc5,web api 2,entityframewo ...
- Microsoft SQL Server 管理 (常用管理及维护命令)
--查询当前连接的实例名 select @@servername --察看任何数据库属性 sp_helpdb master --设置单用户模式,同时立即断开所有用户 alter database No ...
- C#当中的多线程_线程同步
第2章 线程同步 原来以为线程同步就是lock,monitor等呢,看了第二章真是大开眼界啊! 第一章中我们遇到了一个叫做竞争条件的问题.引起的原因是没有进行正确的线程同步.当一个线程在执行操作时候, ...
- sql 嵌套事务学习笔记
以下内容根据此官方文档修改:http://technet.microsoft.com/zh-cn/library/ms189336(v=sql.105).aspx 嵌套事务的使用场景或者说目的主要是为 ...
- asp.net 输出 页面内容 在服务器上
.定义页面内容 按 Ctrl+C 复制代码 <asp:Content ID="BodyContent" runat="server" ContentPla ...
- 实例分析jdom和dom4j的使用和区别
对于xml的解析和生成,我们在实际应用中用的比较多的是JDOM和DOM4J,下面通过例子来分析两者的区别(在这里我就不详细讲解怎么具体解析xml,如果对于xml的解析看不懂的可以先去看下我之前关于do ...