На моей домашней странице я использую datatable
, чтобы показать записи. Но когда я пытаюсь показать данные, данные отображаются корректно, но количество постраничных страниц неверно.Datatable показывает неправильную разбивку на страницы при получении данных с сервера
Мой код
oTableSp = $('#specials-table').dataTable({
"bProcessing": true,
"bServerSide": true,
"sAjaxSource": <myUrl>',
"bJQueryUI": true,
"sPaginationType": "full_numbers",
"iDisplayLength":25,
"lengthMenu": [ 25, 50, 75, 100 ],
"dom": '<"top"f>rt<"bottom row"<"col-md-3"l><"col-md-3"i><"col-md-6"p>>',
"columns": [
{
data: "SpecialName"
},
{
data: "SpecialFrom"
},
{
data : "SpecialTo"
},
{
data : "SpecialBanner"
},
// {
// data : "TermsAndConditions"
// },
{
data: "Actions",
"bSortable" : false,
"aTargets" : [ "no-sort" ]
}
],
"oLanguage": {
"sProcessing": "<img src='../assets/admin/img/ajax-loader_dark.gif'>"
},
"aaSorting": [],
"aoColumnDefs": [
{
"targets": [0,3],
"bSortable" : false
},
],
"dom": '<"top"f>rt<"bottom row"<"col-md-3"l><"col-md-3"i><"col-md-6"p>>',
'fnServerData': function (sSource, aoData, fnCallback) {
sSource = sSource;
aoData.push({
name: 'csrf_tbd_token',
value: tbd_csrf
});
$.ajax
({
'dataType': 'json',
'type': 'POST',
'url': sSource,
'data': aoData,
'success': fnCallback
});
},
'fnCreatedRow': function(nRow, aData, iDataIndex) {
$(nRow).attr('data-id',aData['Id']);
},
"fnRowCallback" : function(nRow, aData, iDisplayIndex){
var html = status_html(aData["active"]);
$("td:eq(4)", nRow).prepend(html);
},
fnDrawCallback: function(oSettings) {
$(".pagination li").removeClass("ui-button ui-state-default");
$(".first.disabled, .previous.disabled, .next.disabled, .last.disabled, .fg-button.active").off("click");
$(".first.disabled a, .previous.disabled a, .next.disabled a, .last.disabled a, .fg-button.active a").attr('href','javascript:void(0);');
$.ajax({
url: <myUrl>',
type: 'POST',
dataType: 'json',
data:{},
success: function(data){
if(data.result == 1){
data.message = jQuery.parseJSON(data.message);
$.each(data.message, function(index, element) {
$('tr[data-id="'+element+'"]').find('.actions').prepend('<a class="approve-sp-all" data-status="1" href="#" title="Approve"><i class="fa fa-fw fa-med fa-thumbs-o-down" style="color:#FF0000"></i></a>');
});
$('#specials-table tr').each(function(){
var elm = $(this);
var data_id = elm.attr('data-id');
if(jQuery.inArray(data_id, data.message) === -1){
$('tr[data-id="'+data_id+'"]').find('.actions').prepend('<a data-status="0" href="#" title="Approved"><i class="fa fa-fw fa-med fa-thumbs-o-up" style="color:#3c763d"></i></a>');
}
});
}
},
error: function(){
}
});
}
});
Когда я смотрю в раздел инспектировать элемента, он показывает
Но Существует только две записи, чтобы показать, как там в aaData
. Я что-то упускаю? Пожалуйста, дайте мне знать.
Любая помощь может быть оценена
Из того, что я понимаю, когда вы устанавливаете serverSide как true, он ожидает, что информация будет предоставлена с помощью ответа ajax. Поскольку вы не используете встроенный ajax, он просто не знает о пейджинге и т. Д. Взгляните на https://datatables.net/manual/server-side – Bindrid
@Bindrid, спасибо за ответ. проверит, что – Arun
@Bindrid, 'sAjaxSource' является URL-адресом ajax, и это правильно. Только счет ошибочен – Arun