具体操作过程如下:
1、首先到自己的项目的pom.xml文件中添加以下代码
<dependency>
<groupId>com.github.pagehelper</groupId>
<artifactId>pagehelper</artifactId>
<version>5.1.2</version>
</dependency>
2、告诉mybatis需要用pagehelper,打开webapp下的applicationcontext.xml文件,将以下代码加入到文件中:
<property name="plugins">
<array>
<bean class="com.github.pagehelper.PageInterceptor">
<property name="properties">
<props>
<prop key="helperDialect">mysql</prop>
<prop key="resonable">true</prop>
</props>
</property>
</bean>
</array>
</property>
3、在service层修改finAll方法, 添加PageHelper.startPage(page,size)代码,如下所示,其中参数page为页面,参数size为一页显示的数目:
@RequestMapping("/findAll.do")
public ModelAndView findAll(@RequestParam(defaultValue = "1") int page,@RequestParam(defaultValue = "5")int size){
List<Userinfo> all=userService.findAll(page,size);
PageInfo pageInfo=new PageInfo(all);
ModelAndView mv=new ModelAndView();
mv.addObject("ps",pageInfo);
mv.setViewName("user-list");
return mv;
}
4、在controller层中修改findAll,具体代码如下:
@RequestMapping("/findAll.do")
public ModelAndView findAll(@RequestParam(defaultValue = "1") int page,@RequestParam(defaultValue = "5")int size){
List<Userinfo> all=userService.findAll(page,size);
PageInfo pageInfo=new PageInfo(all);
ModelAndView mv=new ModelAndView();
mv.addObject("ps",pageInfo);
mv.setViewName("user-list");
return mv;
}
5、修改user-list.jsp文件,将上一页、下一页、首页、尾页界面修改正确,代码如下:
<li><a href="${pageContext.request.contextPath}/user/findAll.do?page=1&size=5" aria-label="Previous">首页</a></li>
<li><a href="${pageContext.request.contextPath}/user/findAll.do?page=${ps.pageNum-1}&size=5">上一页</a></li>
<c:forEach begin="1" end="${ps.pages}" var="pageNumber">
<li><a href="${pageContext.request.contextPath}/user/findAll.do?page=${pageNumber}&size=5">${pageNumber}</a></li>
</c:forEach>
<li><a href="${pageContext.request.contextPath}/user/findAll.do?page=${ps.pageNum+1}&size=5">下一页</a></li>
<li><a href="${pageContext.request.contextPath}/user/findAll.do?page=${ps.pages}&size=5" aria-label="Next">尾页</a></li>
最后就成功实现了分页的功能,页面截图如下: