Spring mvc 使用SpringMVC、JPA和Datatables进行分页
我想在Spring控制器和使用datatables的视图中使用分页。在控制器中,我使用具有分页支持的Spring数据存储库:Spring mvc 使用SpringMVC、JPA和Datatables进行分页,spring-mvc,jpa,datatables,spring-data-jpa,Spring Mvc,Jpa,Datatables,Spring Data Jpa,我想在Spring控制器和使用datatables的视图中使用分页。在控制器中,我使用具有分页支持的Spring数据存储库: @GetMapping("my/url") public String listAll( Model model, @PageableDefault(size=200, sort="name") Pageable pageable) { Page<MyEntity> page = repository.findAll(p
@GetMapping("my/url")
public String listAll(
Model model,
@PageableDefault(size=200, sort="name") Pageable pageable)
{
Page<MyEntity> page = repository.findAll(pageable);
model.addAttribute("page", page);
return "path-to-html-resource";
}
另外,如何编写datatables定义的ajax部分,以便来回传递Spring pageable对象?以及如何将datatable按钮连接到分页索引?您可以使用以下结构: 控制器:
@RequestMapping(value = "/my/url/list")
public ResponseEntity listAllTable(@RequestParam("draw") int draw,
@RequestParam("start") int start,
@RequestParam("length") int length) {
int page = start / length; //Calculate page number
Pageable pageable = PageRequest.of(
page,
length ,
new Sort(
Sort.Direction.DESC ,
"name"
)
) ;
Page<MyEntity> responseData = repository.findAll(pageable);
DataTable dataTable = new DataTable();
dataTable.setData(responseData.getContent());
dataTable.setRecordsTotal(responseData.getTotalElements());
dataTable.setRecordsFiltered(responseData.getTotalElements());
dataTable.setDraw(draw);
dataTable.setStart(start);
return ResponseEntity.ok(dataTable);
}
public class DataTable<T> {
private int draw;
private int start;
private long recordsTotal;
private long recordsFiltered;
private List<T> data;
// setter and getter ...
}
$('#mainTable').DataTable({
"processing": true,
"serverSide": true,
"pageLength": 10,
"searching": false,
"info" : true,
"ajax": {
"url": "/my/url/list",
"method":"get",
"dataSrc": function (response) {
var data = response.data; // your data list
var all = [];
for (var i = 0; i < data.length; i++) {
var row = {
rows: response.start + i + 1,
name: data[i].name, // name ... ,
validFrom: data[i].validFrom,
validTo: data[i].validTo,
amount: data[i].amount,
currency: data[i].currency,
};
all.push(row);
}
return all;
}
},
"columns": [
{ "data": "name"},
{ "data": "validFrom"},
{ "data": "validTo"},
{ "data": "amount"},
{ "data": "currency"}
]
});
@RequestMapping(value=“/my/url/list”)
公共响应listAllTable(@RequestParam(“draw”)int draw,
@RequestParam(“start”)int start,
@RequestParam(“长度”)int length){
int page=start/length;//计算页码
Pageable Pageable=PageRequest.of(
页
长度,
新种类(
Sort.Direction.DESC,
“姓名”
)
) ;
Page responseData=repository.findAll(可分页);
DataTable=新的DataTable();
setData(responseData.getContent());
setRecordsTotal(responseData.getTotalElements());
setRecordsFiltered(responseData.getTotalElements());
dataTable.setDraw(draw);
dataTable.setStart(开始);
返回ResponseEntity.ok(数据表);
}
数据表类:
@RequestMapping(value = "/my/url/list")
public ResponseEntity listAllTable(@RequestParam("draw") int draw,
@RequestParam("start") int start,
@RequestParam("length") int length) {
int page = start / length; //Calculate page number
Pageable pageable = PageRequest.of(
page,
length ,
new Sort(
Sort.Direction.DESC ,
"name"
)
) ;
Page<MyEntity> responseData = repository.findAll(pageable);
DataTable dataTable = new DataTable();
dataTable.setData(responseData.getContent());
dataTable.setRecordsTotal(responseData.getTotalElements());
dataTable.setRecordsFiltered(responseData.getTotalElements());
dataTable.setDraw(draw);
dataTable.setStart(start);
return ResponseEntity.ok(dataTable);
}
public class DataTable<T> {
private int draw;
private int start;
private long recordsTotal;
private long recordsFiltered;
private List<T> data;
// setter and getter ...
}
$('#mainTable').DataTable({
"processing": true,
"serverSide": true,
"pageLength": 10,
"searching": false,
"info" : true,
"ajax": {
"url": "/my/url/list",
"method":"get",
"dataSrc": function (response) {
var data = response.data; // your data list
var all = [];
for (var i = 0; i < data.length; i++) {
var row = {
rows: response.start + i + 1,
name: data[i].name, // name ... ,
validFrom: data[i].validFrom,
validTo: data[i].validTo,
amount: data[i].amount,
currency: data[i].currency,
};
all.push(row);
}
return all;
}
},
"columns": [
{ "data": "name"},
{ "data": "validFrom"},
{ "data": "validTo"},
{ "data": "amount"},
{ "data": "currency"}
]
});
公共类数据表{
私人int抽签;
私人int启动;
私人长唱片公司;
私人长记录过滤;
私人名单数据;
//塞特和盖特。。。
}
javascript:
@RequestMapping(value = "/my/url/list")
public ResponseEntity listAllTable(@RequestParam("draw") int draw,
@RequestParam("start") int start,
@RequestParam("length") int length) {
int page = start / length; //Calculate page number
Pageable pageable = PageRequest.of(
page,
length ,
new Sort(
Sort.Direction.DESC ,
"name"
)
) ;
Page<MyEntity> responseData = repository.findAll(pageable);
DataTable dataTable = new DataTable();
dataTable.setData(responseData.getContent());
dataTable.setRecordsTotal(responseData.getTotalElements());
dataTable.setRecordsFiltered(responseData.getTotalElements());
dataTable.setDraw(draw);
dataTable.setStart(start);
return ResponseEntity.ok(dataTable);
}
public class DataTable<T> {
private int draw;
private int start;
private long recordsTotal;
private long recordsFiltered;
private List<T> data;
// setter and getter ...
}
$('#mainTable').DataTable({
"processing": true,
"serverSide": true,
"pageLength": 10,
"searching": false,
"info" : true,
"ajax": {
"url": "/my/url/list",
"method":"get",
"dataSrc": function (response) {
var data = response.data; // your data list
var all = [];
for (var i = 0; i < data.length; i++) {
var row = {
rows: response.start + i + 1,
name: data[i].name, // name ... ,
validFrom: data[i].validFrom,
validTo: data[i].validTo,
amount: data[i].amount,
currency: data[i].currency,
};
all.push(row);
}
return all;
}
},
"columns": [
{ "data": "name"},
{ "data": "validFrom"},
{ "data": "validTo"},
{ "data": "amount"},
{ "data": "currency"}
]
});
$('mainTable')。数据表({
“处理”:对,
“服务器端”:正确,
“页面长度”:10,
“搜索”:错误,
“信息”:正确,
“ajax”:{
“url”:“/my/url/list”,
“方法”:“获取”,
“dataSrc”:功能(响应){
var data=response.data;//您的数据列表
var all=[];
对于(变量i=0;i