7 R*_*eds 5 ajax datatable jquery
我在一个小项目中使用jQuery DataTables,ajax和Bootstrap.它主要是工作,我正在测试错误状态.我已经为DataTables表设置了我的html.table-responsive周围有一个div <table>.
<div id="errorDiv"></div>
<div id="resultTableDiv" class="table-responsive">
<table id="resultTable" class="table table-striped table-bordered table-hover table-condensed" cellspacing="0">
<thead>
<tr>
<th>...</th>
...
</tr>
</thead>
<tfoot>
<tr>
<th>...</th>
...
</tr>
</tfoot>
</table>
</div>
</div>
Run Code Online (Sandbox Code Playgroud)
在DataTables init中,我设置了ajax调用并指定了一个error回调函数.这"工作",我可以强制服务器端ajax代码中的错误,并触发回调.我可以按照自己的意愿处理返回的错误.
我的问题是,当ajax调用启动时,表体被Processing消息"替换" .这很好,除非当ajax通过回调报告错误时,处理消息仍然存在,我还没有弄清楚如何通过DataTables方法或API调用使其消失.
我的错误回调看起来像
function ajaxError(jqXHR, textStatus, errorThrown) {
var obj = jQuery.parseJSON(jqXHR.responseText);
if (obj && obj.Error) {
$('#errorDiv').html("<p>" + obj.Error + "</p>");
}
}
Run Code Online (Sandbox Code Playgroud)
我有一个"全局"变量,它包含DataTables表定义.它在jQuery ready函数中设置
var table;
$(function () {
$('#errorDiv').empty();
$('#resultTable').show();
table = $('#resultTable').DataTable({
paging: false,
processing: true,
autoWidth: false,
ordering: false,
ajax: {
url: "ions.cgi",
dataType: 'json',
dataSrc: "LIST",
error: ajaxError
}, ...
Run Code Online (Sandbox Code Playgroud)
在错误回调中,我尝试了以下所有方法:
table.clear().draw(); // does nothing
table.fnRedraw(); // says that function does not exist
Run Code Online (Sandbox Code Playgroud)
在此错误状态下,应如何Processing重置消息?
vca*_*les 11
显示处理消息的元素获取id <idOfTable>_processing,因此您可以使用以下命令隐藏它:
$('#resultTable_processing').hide();
Run Code Online (Sandbox Code Playgroud)
这可能已经改变了,id可能会有所不同,但概念就是这样,你可以找出如何识别元素并将其隐藏起来.如果必须,DataTables将再次显示它.
此外,您是否希望处理消息显示在其他ocassions中?因为你可以通过processing: false在DataTable的选项上使用它来永远不会出现它(或者根本就不设置它,因为它是默认行为而不是显示它).
| 归档时间: |
|
| 查看次数: |
8673 次 |
| 最近记录: |