thymeleaf 中 通用的分页方法

简介: thymeleaf 中 通用的分页方法


  1. 在项目中调用api后将数据分页显示,很多的插件都是和数据库相关的使用数据库的 limit 特性 像 pagehelper、Spring Data Jpa这些插件,在这里不适合。这里介绍一种不用后端实现的假分页。主要是对查询后的集合进行下标截取。
  • 工具类代码
import java.util.List;
// 分页工具类
public class PageUtil<T> {
        // 对象记录结果集
        private List<T> list;
        // 总记录数
        private int total = 0;
        // 每页显示记录数
        private int limit = 20;
        // 总页数
        private int pages = 1;
        // 当前页
        private int pageNumber = 1;
        // 是否为第一页
        private boolean isFirstPage = false;
        // 是否为最后一页
        private boolean isLastPage = false;
        // 是否有前一页
        private boolean hasPreviousPage = false;
        // 是否有下一页
        private boolean hasNextPage = false;
        // 导航页码数
        private int navigatePages = 8;
        // 所有导航页号
        private int[] navigatePageNumbers;
        // 尾页
        private int lastPage = 0 ;
        // 首页
        private int firstPage = 1 ;
        // 上一页
        private int prePage = 0;
        // 下一页
        private int nextPage = 0;
        public PageUtil(int pageNumber, int limit, List<T> list) {
            init(list, pageNumber, limit);
        }
        private void init(List<T> list, int pageNumber, int limit){
            //设置基本参数
            this.list = list;
            this.total = list.size();
            this.limit = limit;
            this.pages = (this.total-1)/this.limit+1;
            this.lastPage = pages;
            this.firstPage = 1;
            this.prePage = pageNumber-1;
            this.nextPage = pageNumber+1;
            //根据输入可能错误的当前号码进行自动纠正
            if(pageNumber<1){
                this.pageNumber=1;
            }else if(pageNumber>this.pages){
                this.pageNumber=this.pages;
            }else{
                this.pageNumber=pageNumber;
            }
            //基本参数设定之后进行导航页面的计算
            calcNavigatePageNumbers();
            //以及页面边界的判定
            judgePageBoudary();
        }
        /**
         * 计算导航页
         */
        private void calcNavigatePageNumbers(){
            //当总页数小于或等于导航页码数时
            if(pages<=navigatePages){
                navigatePageNumbers=new int[pages];
                for(int i=0;i<pages;i++){
                    navigatePageNumbers[i]=i+1;
                }
            }else{ //当总页数大于导航页码数时
                navigatePageNumbers=new int[navigatePages];
                int startNum=pageNumber-navigatePages/2;
                int endNum=pageNumber+navigatePages/2;
                if(startNum<1){
                    startNum=1;
                    //(最前navPageCount页
                    for(int i=0;i<navigatePages;i++){
                        navigatePageNumbers[i]=startNum++;
                    }
                }else if(endNum>pages){
                    endNum=pages;
                    //最后navPageCount页
                    for(int i=navigatePages-1;i>=0;i--){
                        navigatePageNumbers[i]=endNum--;
                    }
                }else{
                    //所有中间页
                    for(int i=0;i<navigatePages;i++){
                        navigatePageNumbers[i]=startNum++;
                    }
                }
            }
        }
        /**
         * 判定页面边界
         */
        private void judgePageBoudary(){
            isFirstPage = pageNumber == 1;
            isLastPage = pageNumber == pages && pageNumber!=1;
            hasPreviousPage = pageNumber!=1;
            hasNextPage = pageNumber!=pages;
        }
        /**
         * 得到当前页的内容
         * @return {List}
         */
        public List<T> getList() {
            int endIndex = total;
            if(pageNumber*limit <= total){
                endIndex = pageNumber*limit;
            }
            List<T> pagelist = list.subList((pageNumber-1)*limit, endIndex);
          return pagelist;
        }
    public int getLastPage() {
        return lastPage;
    }
    public void setLastPage(int lastPage) {
        this.lastPage = lastPage;
    }
    public int getFirstPage() {
        return firstPage;
    }
    public void setFirstPage(int firstPage) {
        this.firstPage = firstPage;
    }
    public int getPrePage() {
        return prePage;
    }
    public void setPrePage(int prePage) {
        this.prePage = prePage;
    }
    public int getNextPage() {
        return nextPage;
    }
    public void setNextPage(int nextPage) {
        this.nextPage = nextPage;
    }
        /**
         * 得到记录总数
         * @return {int}
         */
        public int getTotal() {
            return total;
        }
        /**
         * 得到每页显示多少条记录
         * @return {int}
         */
        public int getLimit() {
            return limit;
        }
        /**
         * 得到页面总数
         * @return {int}
         */
        public int getPages() {
            return pages;
        }
        /**
         * 得到当前页号
         * @return {int}
         */
        public int getPageNumber() {
            return pageNumber;
        }
        /**
         * 得到所有导航页号
         * @return {int[]}
         */
        public int[] getNavigatePageNumbers() {
            return navigatePageNumbers;
        }
        public boolean isFirstPage() {
            return isFirstPage;
        }
        public boolean isLastPage() {
            return isLastPage;
        }
        public boolean hasPreviousPage() {
            return hasPreviousPage;
        }
        public boolean hasNextPage() {
            return hasNextPage;
        }
    }
  • 业务处理中的使用
 /**
   * 进入用户列表首页
   * @param model
   * @param map
   *      key: currentPage 当前页码
   * @return 跳转至列表页面
   * @throws Exception 
   */ 
@RequestMapping("/findUserList.do")
    public String findUserList(@RequestParam Map<String, String> map, Model model) throws Exception {
     if (map.size() == 0 || map.get("currentPage").isEmpty()) {
            map.put("currentPage", "0");
         }
     // 查询用户列表 及设置分页信息
     List<UserDTO> userDTOList = userServiceImpl.findUserDTOList();
    // 参数为当前页码、每页显示条数、查询的列表集合
 PageUtil pageInfo = new PageUtil(Integer.valueOf(map.get("currentPage")), 20, userDTOList);
    model.addAttribute("userDTOList", pageInfo.getList());
     model.addAttribute("pageInfo", pageInfo);
    return "findUserDTOList";
    }
  • 页面展示
<table  class="table">
                <tr th:each="flpcDTO : ${userDTOList} ">
                  <td></td>
                </tr>
        </table>
        <div align="center">
            <a class="allpage"><b th:text="'共 '+ ${pageInfo.getPages()}+ ' 页'"></b></a>
            <a  th:href="@{/findUserList.do(currentPage=${pageInfo.getFirstPage()})}"  >首页</a>
            <a th:if="${pageInfo.hasPreviousPage()} == true" th:href="@{/findUserList.do(currentPage=${pageInfo.getPrePage()})}"  >上一页</a>
            <a th:href="@{'/findUserList.do?currentPage=' + ${i}}"  th:each="i :${#numbers.sequence(pageInfo.firstPage, pageInfo.lastPage)}" th:text="  ${i}"   th:class="${pageInfo.getPageNumber() == i}? 'page-item active' :' page-item' "></a>
            <a th:if="${pageInfo.hasNextPage()} == true" th:href="@{/findUserList.do(currentPage=${pageInfo.getNextPage()})}" >下一页</a>
            <a th:href="@{/findUserList.do(currentPage=${pageInfo.getLastPage()})}" >尾页</a>
        </div>


相关文章
|
Java Spring 容器
@Resource 这个注解什么用啊
@Resource 这个注解什么用啊
785 0
|
算法 Java API
Spring Cloud Gateway简单使用
Spring Cloud Gateway简单使用
758 0
Thymeleaf内置对象、定义变量、URL参数及标签自定义属性
Thymeleaf内置对象、定义变量、URL参数及标签自定义属性
661 0
|
IDE Java 编译器
浅析@SneakyThrows
在日常的开发中,相信你一定使用过Lombok,它是一款开源的可用于Java平台的代码生成库。我们在定义JavaBean的时候,会使用IDE自动生成构造方法、getter、setter、equals、hashCode、toString等方法,一旦类的属性有修改就要重新生成,通过使用Lambok的简单注解来精简代码就能达到消除冗长代码的目的。
1053 0
浅析@SneakyThrows
|
JSON 数据格式
net.sf.json.JSONObject 和org.json.JSONObject 的差别
net.sf.json.JSONObject 和org.json.JSONObject 的差别
|
SQL 前端开发 JavaScript
Spring Boot + Thymeleaf 使用PageHelper实现分页
Spring Boot + Thymeleaf 使用PageHelper实现分页
423 0
|
前端开发 JavaScript Java
解决springboot+vue+mybatis中,将后台数据分页显示在前台,并且根据页码自动跳转对应页码信息
该博客文章讲述了如何在Spring Boot + Vue + MyBatis的项目中实现后台数据的分页查询,并在前端进行显示和页码跳转,包括后端的分页查询实现、前端与后端的交互以及使用Element UI进行分页展示的方法。
|
XML JavaScript 前端开发
如何在JavaScript中设置多个样式属性?
【6月更文挑战第29天】如何在JavaScript中设置多个样式属性?
898 3
|
前端开发 数据库
文本----富文本数据如何存入到数据库当中,解决方法,看其他大佬写的文章
文本----富文本数据如何存入到数据库当中,解决方法,看其他大佬写的文章
文本----富文本数据如何存入到数据库当中,解决方法,看其他大佬写的文章
成功解决:java: 找不到符号 符号: 方法 getSort() 位置: 类型为com.atguigu.gulimall.product.entity.CategoryEntity的变量 menu1
这篇文章讨论了Java中遇到的一个常见错误:"java: 找不到符号 符号: 方法 getSort() 位置: 类型为com.atguigu.gulimall.product.entity.CategoryEntity的变量 menu1",即在尝试调用一个不存在的方法时出现的问题,并提供了相应的解决方法。