当我调用服务器端DataTables搜索时,我得到一项,这是AJAX调用的响应:
{draw: 1, recordsTotal: 1, recordsFiltered: 18,…}
data: [{...}]
draw: 1
recordsFiltered: 18
recordsTotal: 1
而DataTables则认识到这一点:
Showing 1 to 10 of 18 entries (filtered from 1 total entries)
这是我当前的配置(我目前正在使用流水线,如下所述:https://datatables.net/examples/server_side/pipeline.html)
var table = $('#table').DataTable({
"processing": true,
"serverSide": true,
"ajax": $.fn.dataTable.pipeline({
url: '/url',
pages: 5 // number of pages to cache,
}),
"pagingType": "full_numbers",
"columns": columnData,
"order": [[1, "desc"]]
});
当我在Chrome浏览器控制台中调用
table.page.info()
时,{page: 0, pages: 2, start: 0, end: 10, length: 10, …}
end: 10
length: 10
page: 0
pages: 2
recordsDisplay: 18
recordsTotal: 1
serverSide: true
start: 0
根据先前的信息和Datatables正确搜索的事实,我认为我的服务器端实现是正确的。但是,我不知道是什么原因导致数据表显示两页,而不是每页显示十条记录。
最佳答案
希望这对您有所帮助。recordsTotal
用于显示总记录并为记录数设置分页。数据表具有基于recordsTotal
设置分页的内部功能。
而recordsDisplay
用于在特定页面上显示记录。单击分页时,对于服务器端,它将根据长度和偏移量获取新记录。
因此,代码中的问题是您的recordsDisplay
为18,而recordsTotal
为1。这是不可能的。
->不可能recordsDisplay
> recordsTotal
。