我有以下代码,我想根据城市数据隐藏某些列。 我使用了回调函数,但它破坏了表格。 如果我改变其中的某些内容,它也会出错。
var hide_col = $('#table_id').dataTable().api();
var table = $('#table_id');
var oTable = table.dataTable({
"destroy": true,
"processing": true,
"serverSide": true,
"ajax": "/app/get-data/"+val1+'/'+val2+'/'+val3+'/',
"searching": false,
"ordering": true,
"paging": true,
"columnDefs": [
{"targets": 1, "orderable": false},{"targets": 2, "orderable": false},
{"targets": 3, "orderable": false},{"targets": 4, "orderable": false},
{"targets": 5, "orderable": false},{"targets": 6, "orderable": false},
{"targets": 7, "orderable": false},{"targets": 8, "orderable": false},
{"targets": 9, "orderable": false},{"targets": 10, "orderable": false},
{"targets": 11, "orderable": false},{"targets": 12, "orderable": false},
{"targets": 13, "orderable": false},{"targets": 14, "orderable": false},
{"targets": 15, "orderable": false},{"targets": 16, "orderable": false},
{"targets": 17, "orderable": false},{"targets": 18, "orderable": false},
{"targets": 19, "orderable": false},{"targets": 20, "orderable": false},
{"targets": 21, "orderable": false},{"targets": 22, "orderable": false},
{"targets": 23, "orderable": false},{"targets": 24, "orderable": false},
{"width": "200%", className: "dt-left", "targets": 0}
],
buttons: [{ extend: 'print',
className: 'btn dark btn-outline' },
{ extend: 'copy',
className: 'btn red btn-outline' },
{ extend:'pdf',
orientation:'landscape',
className: 'btn green btn-outline',
exportOptions: {
columns: [0,1,2,3,4,5,6,7,8,9,10,11,12] }},
{ extend: 'excel',
className: 'btn yellow btn-outline' },
{ extend: 'csv',
className: 'btn purple btn-outline' },
{ extend: 'colvis',
className: 'btn dark btn-outline',
text: 'Columns' }
],
// setup responsive extension: http://datatables.net/extensions/responsive/
responsive: false,
"order": [
[0, 'asc']
],
"lengthMenu": [
[10, 20, 50, 100],
[10, 20, 50, 100] // change per page values here] // change per page values here
],
// set the initial value
"pageLength": 10,
"initComplete": function(settings, json) {
if (settings.jqXHR.responseJSON.city == 'A'){
hide_col.columns([6,7,8,12,16,17,18,19,20]).visible(false);
hide_col.columns([9,10,11,13,14,15,21,22,23,24]).visible(true);
}
else if (settings.jqXHR.responseJSON.city == 'B'){
hide_col.columns([9,10,11,13,14,15,21,22,23,24]).visible(false);
hide_col.columns([6,7,8,12,16,17,18,19,20]).visible(true);
}
}
});
我也在使用一个回调但似乎我做错了。请帮忙。谢谢。
答案 0 :(得分:0)
我可以看到您在实际初始化之前尝试访问Datatables API
。事实上,我相信您可以完全摆脱hide_col
变量并使用oTable
变量调用columns().visible()。
删除此行:
var hide_col = $('#table_id').dataTable().api();
并更改此功能以使用oTable
代替hide_col
:
"initComplete": function(settings, json) {
if (settings.jqXHR.responseJSON.city == 'A'){
oTable.columns([6,7,8,12,16,17,18,19,20]).visible(false);
oTable.columns([9,10,11,13,14,15,21,22,23,24]).visible(true);
}
else if (settings.jqXHR.responseJSON.city == 'B'){
oTable.columns([9,10,11,13,14,15,21,22,23,24]).visible(false);
oTable.columns([6,7,8,12,16,17,18,19,20]).visible(true);
}
}