繁体   English   中英

为 jquery datatables ajax 调用设置错误处理程序

[英]set an error handler for jquery datatables ajax call

当ajax调用出现问题(即服务器不响应)时,我试图有一个自定义错误处理程序,以将新数据加载到我的数据表中。

$table.DataTable().ajax.url(ajaxURL).load();

默认情况下,它会显示一个警报,我可以使用以下设置将其更改为引发 javascript 错误:

$.fn.dataTable.ext.errMode = 'throw';

但是有了这个,我只是在控制台中记录了一个错误,我不确定如何捕获这个抛出的错误,所以我仍然无法提供我自己的错误处理程序。

文档中还列出了一个错误事件,但这似乎没有被触发,因此以下内容永远不会发出警报。

$table.on( 'error', function () { alert( 'error' );} );

到目前为止,我发现的所有其他内容都是针对遗留代码的,例如设置 fnServerData,我想避免进入。

1.10 API有没有设置ajax错误回调的方法?

Datatables v1.10.5( 2015 年 2 月 10 日发布)中添加了新的错误事件处理。

$.fn.dataTable.ext.errMode = function ( settings, helpPage, message ) { 
    console.log(message);
};

请参阅此处的文档:
https://datatables.net/reference/event/error
https://cdn.datatables.net/1.10.5/

使用 Ajax 错误函数记录错误:

$('#table').DataTable({
    ajax: {
        dataType: "JSON",  
        type: "POST",
        url: url,
        data: [],
        async: true,
        error: function (xhr, error, code) {
            console.log(xhr, code);
        }
    },
});

将事件用作自定义错误处理程序

$(document).ready(function () {
    $('#myTable').on('error.dt', function (e, settings, techNote, message) {
        console.log('An error has been reported by DataTables: ', message);
    }).DataTable({
        "displayLength": 15,
        "ajax": {
          ....

我正在使用 Datatables 1.10.19 + Bootstrap,并且提供的大多数解决方案(包括上面接受的解决方案)都不起作用。 但是,我设法捕获错误如下:

 "ajax" : {
    "datatype" : "json",
    "contentType" : "application/json",
    "method" : "GET",
    "url" : $url,
    "data" : { x : y },
    "dataSrc": function (data) {
      if (data.result == "OK"){
        return data.yourObj;
      }else{
        // hide processing or any loading modal here
        // display error on page or something
        console.log("Error: " + parseResultData(data.resultData));
        data.yourObj = [] //since datatables will be checking for the object as array
        return data.yourObj;
      }                           
    } 
  }

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM