简单分页使用插件

分页所需jar包:
<!-- 分页 -->
<dependency>
<groupId>com.github.pagehelper</groupId>
<artifactId>pagehelper</artifactId>
<version>4.0.0</version>
</dependency>

页面:
<div class="row">
<div style="font-weight: bold;font-size: 16px;font-family:'仿宋体';" class="col-md-7">
<i class="blue">${pageInfo.total}</i>条记录,
当前显示第&nbsp;<i class="blue">${pageInfo.pageNum}/${pageInfo.pages}</i>&nbsp;页
</div>
<nav aria-label="Page navigation">
<ul class="pagination">
<c:if test="${!pageInfo.isFirstPage}">
<li><a href="<%=basePath%>/message/selectMessage.action?PageNum=1">首页</a></li>
<li><a href="<%=basePath%>/message/selectMessage.action?PageNum=${pageInfo.pageNum-1 }"
aria-label="Previous">
<span aria-hidden="true">&laquo;</span>
</a>
</li>
</c:if>
<c:forEach items="${pageInfo.navigatepageNums }" var="num">
<c:if test="${num == pageInfo.pageNum }">
<li class="active"><a
href="<%=basePath%>/message/selectMessage.action?PageNum=${num }">${num }</a>
</li>
</c:if>
<c:if test="${num != pageInfo.pageNum }">
<li><a href="<%=basePath%>/message/selectMessage.action?PageNum=${num }">${num }</a></li>
</c:if>
</c:forEach>
<c:if test="${!pageInfo.isLastPage}">
 <li>
<a href="<%=basePath%>/message/selectMessage.action?PageNum=${pageInfo.pageNum+1 }"
aria-label="Next">
<span aria-hidden="true">&raquo;</span>
</a>
</li>
<li><a href="<%=basePath%>/message/selectMessage.action?PageNum=${pageInfo.lastPage}">尾页</a></li>
</c:if>
</ul>
</nav>
</div>
controller:
//查询所有的消息
@RequestMapping("/selectMessage")
public String selectMessage(Model model,@RequestParam(value = "PageNum", defaultValue = "1") Integer PageNum, @RequestParam(value = "PageSize", defaultValue = "5") Integer PageSize) {
PageHelper.startPage(PageNum, PageSize);
List<Message> list = messageService.findMessage();
PageInfo objectPageInfo = new PageInfo(list);
model.addAttribute("pageInfo", objectPageInfo);
model.addAttribute("list", list);
List<User> users = userService.findUser();
model.addAttribute("user", users);
return "get";
}

mybatis-config.xml:
<!--分页拦截器-->
<plugins>
<!-- com.github.pagehelper为PageHelper类所在包名 -->
<plugin interceptor="com.github.pagehelper.PageHelper">
<property name="dialect" value="mysql"/>
<!-- 该参数默认为false -->
<!-- 设置为true时,会将RowBounds第一个参数offset当成pageNum页码使用 -->
<!-- 和startPage中的pageNum效果一样-->
<property name="offsetAsPageNum" value="true"/>
<!-- 该参数默认为false -->
<!-- 设置为true时,使用RowBounds分页会进行count查询 -->
<property name="rowBoundsWithCount" value="true"/>
<!-- 设置为true时,如果pageSize=0或者RowBounds.limit = 0就会查询出全部的结果 -->
<!-- (相当于没有执行分页查询,但是返回结果仍然是Page类型)-->
<property name="pageSizeZero" value="true"/>
<!-- 3.3.0版本可用 - 分页参数合理化,默认false禁用 -->
<!-- 启用合理化时,如果pageNum<1会查询第一页,如果pageNum>pages会查询最后一页 -->
<!-- 禁用合理化时,如果pageNum<1或pageNum>pages会返回空数据 -->
<property name="reasonable" value="false"/>
<!-- 3.5.0版本可用 - 为了支持startPage(Object params)方法 -->
<!-- 增加了一个`params`参数来配置参数映射,用于从Map或ServletRequest中取值 -->
<!--
可以配置pageNum,pageSize,count,pageSizeZero,reasonable,不配置映射的用默认值 -->
<!-- 不理解该含义的前提下,不要随便复制该配置 -->
<property name="params" value="pageNum=start;pageSize=limit;"/>
<!-- always总是返回PageInfo类型,check检查返回类型是否为PageInfo,none返回Page -->
<property name="returnPageInfo" value="check"/>
</plugin>
</plugins>



posted @ 2017-09-01 20:41  Dream{*}  阅读(389)  评论(0编辑  收藏  举报