From b5db6fe186cc491650711d8cdbaf6652d0a4cac4 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E7=96=AF=E7=8B=82=E7=9A=84=E7=8B=AE=E5=AD=90li?= <15040126243@163.com> Date: Fri, 3 Dec 2021 15:57:11 +0800 Subject: [PATCH] =?UTF-8?q?update=20=E9=87=8D=E6=9E=84=E5=88=86=E9=A1=B5?= =?UTF-8?q?=E5=B7=A5=E5=85=B7=20=E4=BD=BF=E7=94=A8=E5=88=86=E9=A1=B5?= =?UTF-8?q?=E5=AE=9E=E4=BD=93=E7=B1=BB=20=E8=BF=87=E6=9C=9F=E6=96=B9?= =?UTF-8?q?=E6=B3=95=E6=A0=87=E6=B3=A8=E8=BF=87=E6=9C=9F=203.6.0=20?= =?UTF-8?q?=E7=A7=BB=E9=99=A4?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../com/ruoyi/common/utils/PageUtils.java | 45 +++++++++++++++++++ 1 file changed, 45 insertions(+) diff --git a/ruoyi-common/src/main/java/com/ruoyi/common/utils/PageUtils.java b/ruoyi-common/src/main/java/com/ruoyi/common/utils/PageUtils.java index abc42ddd2..4b3dd9b91 100644 --- a/ruoyi-common/src/main/java/com/ruoyi/common/utils/PageUtils.java +++ b/ruoyi-common/src/main/java/com/ruoyi/common/utils/PageUtils.java @@ -4,6 +4,7 @@ import cn.hutool.core.util.ObjectUtil; import cn.hutool.http.HttpStatus; import com.baomidou.mybatisplus.core.metadata.OrderItem; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; +import com.ruoyi.common.core.domain.PageQuery; import com.ruoyi.common.core.page.PagePlus; import com.ruoyi.common.core.page.TableDataInfo; import com.ruoyi.common.utils.sql.SqlUtil; @@ -20,21 +21,25 @@ public class PageUtils { /** * 当前记录起始索引 */ + @Deprecated public static final String PAGE_NUM = "pageNum"; /** * 每页显示记录数 */ + @Deprecated public static final String PAGE_SIZE = "pageSize"; /** * 排序列 */ + @Deprecated public static final String ORDER_BY_COLUMN = "orderByColumn"; /** * 排序的方向 "desc" 或者 "asc". */ + @Deprecated public static final String IS_ASC = "isAsc"; /** @@ -53,7 +58,10 @@ public class PageUtils { * @param domain 实体 * @param vo 实体 * @return 分页对象 + * @deprecated 3.6.0 删除 请使用 {@link PageUtils#buildPagePlus(PageQuery)} + * 由于使用 Servlet 获取只能从 param 获取 灵活性降低 故将传参操作交给用户 */ + @Deprecated public static PagePlus buildPagePlus() { Integer pageNum = ServletUtils.getParameterToInt(PAGE_NUM, DEFAULT_PAGE_NUM); Integer pageSize = ServletUtils.getParameterToInt(PAGE_SIZE, DEFAULT_PAGE_SIZE); @@ -70,6 +78,23 @@ public class PageUtils { return page; } + public static PagePlus buildPagePlus(PageQuery pageQuery) { + Integer pageNum = ObjectUtil.defaultIfNull(pageQuery.getPageNum(), DEFAULT_PAGE_NUM); + Integer pageSize = ObjectUtil.defaultIfNull(pageQuery.getPageSize(), DEFAULT_PAGE_SIZE); + String orderByColumn = pageQuery.getOrderByColumn(); + String isAsc = pageQuery.getIsAsc(); + if (pageNum <= 0) { + pageNum = DEFAULT_PAGE_NUM; + } + PagePlus page = new PagePlus<>(pageNum, pageSize); + OrderItem orderItem = buildOrderItem(orderByColumn, isAsc); + if (ObjectUtil.isNotNull(orderItem)) { + page.addOrder(orderItem); + } + return page; + } + + @Deprecated public static Page buildPage() { return buildPage(null, null); } @@ -79,7 +104,10 @@ public class PageUtils { * * @param domain 实体 * @return 分页对象 + * @deprecated 3.6.0 删除 请使用 {@link PageUtils#buildPage(PageQuery)} + * 由于使用 Servlet 获取只能从 param 获取 灵活性降低 故将传参操作交给用户 */ + @Deprecated public static Page buildPage(String defaultOrderByColumn, String defaultIsAsc) { Integer pageNum = ServletUtils.getParameterToInt(PAGE_NUM, DEFAULT_PAGE_NUM); Integer pageSize = ServletUtils.getParameterToInt(PAGE_SIZE, DEFAULT_PAGE_SIZE); @@ -96,6 +124,23 @@ public class PageUtils { return page; } + public static Page buildPage(PageQuery pageQuery) { + Integer pageNum = ObjectUtil.defaultIfNull(pageQuery.getPageNum(), DEFAULT_PAGE_NUM); + Integer pageSize = ObjectUtil.defaultIfNull(pageQuery.getPageSize(), DEFAULT_PAGE_SIZE); + String orderByColumn = pageQuery.getOrderByColumn(); + String isAsc = pageQuery.getIsAsc(); + if (pageNum <= 0) { + pageNum = DEFAULT_PAGE_NUM; + } + Page page = new Page<>(pageNum, pageSize); + OrderItem orderItem = buildOrderItem(orderByColumn, isAsc); + if (ObjectUtil.isNotNull(orderItem)) { + page.addOrder(orderItem); + } + return page; + } + + private static OrderItem buildOrderItem(String orderByColumn, String isAsc) { // 兼容前端排序类型 if ("ascending".equals(isAsc)) {