bog*_*usu 6 sorting pagination spring-data-jpa spring-boot
我正在为一组表开发管理界面。我需要实现列表、排序、过滤和分页等功能。
我使用 Spring Boot 作为启动器,使用 Spring Data Jpa 作为存储库。我在网上搜索了一些关于包含上述所有功能的完整解决方案的示例。我发现的内容几乎包括所有内容,但如果有分页和排序,则没有过滤,反之亦然。
现在我将过滤器存储在会话使用的应用程序对象中,@ModelAttribute
但我知道现在这是一个很好的设计,因为应用程序将扩展并且变得难以维护。我也在使用Page
和Pagination
用于分页目的并Specifications
用于过滤。
我想要的是在单个请求中提交所有数据,即:搜索字段、排序字段和当前页面。当然,如果搜索字段不为空,分页将被重新初始化。
另一件事是我不想使用 jQuery 数据表,而是使用纯 HTML 和表单提交。
以下是我找到的一些教程和示例:
提前致谢
包括编辑html 表单
这是我的表格和分页部分的结构:
<form method=post action=someLink>
<table> -populated from controller using Thymeleaf - </table>
<div class=pagination>
<ul> - actually this div is build using the page object returned from server -
<li><a href=link/?page=;size=;>1</a></li>
<li><a href=link/?page=;size=;>2</a></li>
<li><a href=link/?page=;size=;>3</a></li>
</ul>
</div>
</form>
Run Code Online (Sandbox Code Playgroud)
如您所见,表单与我的分页 div 分开。当我点击一个页码时,一个获取请求被发送到服务器并使用存储的过滤器执行查询。当我提交表单时,页码不会被考虑在内,因为页数可能会发生变化。
所以我的问题是如何构建表单以在一次提交中包含分页。
我正在考虑而不是使用 a 来使用输入元素,因此在服务器上我可以从中读取数据。我不知道如何使用 pageable 属性提交该帖子请求。
谢谢
您要做的第一件事是启用 Spring Data Web 支持。如果您使用 Spring Boot,它可能是由 Spring Boot 激活的。
启用 Spring Data Web 支持后,您可以通过设置这些请求参数的值来指定当前页面、页面大小和排序选项:
现在,您可以通过将新的org.springframework.data.domain.Pageable方法参数添加到控制器方法中,将请求的页面信息“注入”到控制器方法中。在您的情况下,控制器方法可能如下所示:
@RequestMapping(value = "/search", method=RequestMethod.POST)
public String search(@ModelAttribute("searchFilter") FilterDTO filter, Pageable page) {
//Add logic here
return "results";
}
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
13793 次 |
最近记录: |