SSM整合-分页
**
前端代码
<ul class="pagination justify-content-center">
<li class="page-item" th:class="|page-item ${page.pageCru==1? 'disabled':''}|">
<a class="page-link" th:href="@{|/passage/${type}/1/${keyword == null ? '':'/'+ keyword}|}" >首页</a>
</li>
<li th:class="|page-item ${page.pageCru==1?'disabled':''}|">
<a class="page-link" th:href="@{|/passage/${type}/${page.pageCru - 1}${keyword == null ? '':'/'+ keyword}|}">上一页</a>
</li>
<!--numbers.sequence 生成一个 page.from 到 page.to 的连续整数数组-->
<li th:each=" i : ${#numbers.sequence(1,page.pageCount)}" >
<a class="page-link" th:href="@{|/passage/${type}/${i}${keyword == null ? '':'/'+ keyword}|}" th:text="${i}"></a>
<!-- th:href="@{|/passage/list?cur=${i}|}" th:text="${i}"-->
</li>
<li th:class="|page-item ${page.pageCru==page.pageCount ? 'disabled':''}|">
<a class="page-link" th:href="@{|/passage/${type}/${page.pageCru + 1}${keyword == null ? '':'/'+ keyword}|}">下一页</a>
</li>
<li class="page-item" th:class="|page-item ${page.pageCru==page.pageCount ? 'disabled':''}|">
<!-- ${kword == null ? '/'+${kword}:''} -->
<a class="page-link" th:href="@{|/passage/${type}/${page.pageCount}${keyword == null ? '':'/'+ keyword}|}">末页</a>
</li>
<!-- /模块名/类型/当前页,是否有关键字 ? -->
</ul>
Controller
@GetMapping("/{type}/{cur}")
public String list(ModelMap map, @PathVariable String type,@PathVariable Integer cur){
System.out.println("type:"+type);
System.out.println("cur:"+cur);
// 创建一个分页对象
Page page = new Page();
page.setPageCru(cur);
// 根据类型查询分页内容
Page newPage = passageService.listPage(page,type);
// 将数据放入map中
map.put("page",newPage);
map.put("type",type);
//
return "user/index";
}
@GetMapping("/{type}/keyword/{cur}")
public String listForSearchForm(ModelMap map,
@PathVariable String type,
@PathVariable Integer cur,
@RequestParam String kword){
// 创建一分页对象
Page page = new Page();
// 设置当前页码
page.setPageCru(cur);
// 查询当前页数据
Page newPage = passageService.listSearchPage(page,kword);
System.out.println("内容条数:"+newPage.getPassages().size());
// 将数据放入map中
map.put("page",newPage);
map.put("type",type);
map.put("keyword",kword);
return "user/index";
}
分页对象
@Data
public class Page {
//总记录数
private Integer pageTotal;
//一页的大小
private Integer pageSize = 5;
//一共多少页
private Integer pageCount;
//当前页码
private Integer pageCru ;
//当前页的数据
private List<IndexUserVo> passages;
}
Service
@Override
public Page listPage(Page page, String type){
//一共多少条记录
Integer pageTotal = passageMapper.selectTotal();
//一页的内容条数
Integer pageSize = page.getPageSize();
Integer count = 0;
if (pageTotal % pageSize == 0){
count = pageTotal / pageSize;
}else if (pageTotal % pageSize != 0){
count = pageTotal / pageSize + 1;
}
Integer index = 0;
Integer pageCru = page.getPageCru();
if (pageCru==1){
index = 0;
}else if (pageCru>1){
index = (pageCru-1)*pageSize;
}
List<IndexUserVo> listPage = null;
if ("list".equals(type)){
listPage = passageMapper.selectPageList(page.getPageSize(),index);
}else if (("newest".equals(type))){
listPage = passageMapper.selectNewPageList(page.getPageSize(),index);
}else if ("hottest".equals(type)){
listPage = passageMapper.selectHotPageList(page.getPageSize(),index);
}
//一共多少页
page.setPageCount(count);
// 一共多少条记录
page.setPageTotal(pageTotal);
// 当前页数据
page.setPassages(listPage);
//
return page;
}
@Override
public Page listSearchPage(Page page, String keyword) {
//一共有多少条记录
Integer pageTotal = passageMapper.selectSearchTotal(keyword);
//一共有多少页
Integer count = 0;
Integer pageSize = page.getPageSize();
if (pageTotal % pageSize == 0){
count = pageTotal / pageSize;
}else if (pageTotal % pageSize != 0){
count = pageTotal / pageSize + 1;
}
//计算起始索引
Integer index = 0;
Integer pageCru = page.getPageCru();
if (pageCru==1){
index = 0;
}else if (pageCru>1){
index = (pageCru-1)*pageSize;
}
//查找数据
List<IndexUserVo> indexUserVos = passageMapper.selectSearchList(pageSize, index, keyword);
//封装成Page对象
page.setPassages(indexUserVos);
page.setPageCount(count);
page.setPageTotal(pageTotal);
return page;
}