jQuery,DataTables,ajax错误处理:摆脱"处理"消息

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的选项上使用它来永远不会出现它(或者根本就不设置它,因为它是默认行为而不是显示它).