DataTables警告-为第0行第0列请求未知参数'0' [英] DataTables warning - Request unknown parameter '0' for row 0, column 0

查看:75
本文介绍了DataTables警告-为第0行第0列请求未知参数'0'的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在使用jQuery DataTable来显示使用存储过程和Web服务从数据库中获取的数据.我可以使用Fiddler很好地运行SP或服务,但是在填充DataTable时,出现了记录为

I'm using a jQuery DataTable to display data taken from a database using a stored procedure and web service. I can run the SP or service using Fiddler just fine, but when it comes to populating the DataTable I get the error documented here. In my specific case the message is:

"DataTables警告:表id = tblCashRecord-请求的未知参数'0'对于第0行,第0列"

"DataTables warning: table id=tblCashRecord - Requested unknown parameter '0' for row 0, column 0"

然后发生的是,我的DataTable显示了正确的行数,但是所有单元格都为空.

What happens then is that my DataTable shows the correct number of rows, but all of the cells are empty.

我很确定HTML表格中的列数与我要使用aoColumns推送的列数相同(是4),但是我可能是错的.我知道有很多相同的问题,但是是唯一的一个我发现可能有用,可能有用,并且我也尝试了,但未成功.

I'm pretty sure the number of columns in the HTML table are the same as the number of columns I'm pushing to using aoColumns (it's four), but I could be wrong. I know there are plenty of the same question being asked, but this is the only one I found useful that might be relevant, and I've also tried this without success.

我的HTML表格:

<table id="tblCashRecord" class="table table-bordered">
    <thead>
        <tr>
            <th>Kiosk Name</th>
            <th>Service Type</th>
            <th>Transaction Timestamp</th>
            <th>Amount (RM)</th>
        </tr>
    </thead>
    <tbody>
    </tbody>
    <tfoot>
        <tr>
            <th colspan="3" style="text-align: right">Total:</th>
            <th><span id="totalAmount" style="margin-left: -8px;"></span></th>
        </tr>
    </tfoot>
</table>

我的Javascript:

My Javascript:

$.ajax({
                        type: "POST",
                        url: "../Services/Report.svc/GetCashPaymentRecord/?s=" + session + "&r=" + reference,
                        data: "{\"kioskID\":" + JSON.stringify(kioskID) + "," + "\"startDate\": " + JSON.stringify(startDate) + "," + "\"endDate\":" + JSON.stringify(endDate) + "}",
                        contentType: "application/json; charset=utf-8",
                        dataType: "json",
                        success: function (response) {
                            if (response.success == true) {
                                if (response.cashPayment != null && response.cashPayment.length > 0) {
                                    cashList = response.cashPayment;
                                    var data = { "aaData": [] };

                                    $('#tblCashRecord').dataTable().fnClearTable();
                                    $('#tblCashRecord').dataTable().fnDestroy();

                                    $.each(response.cashPayment, function (item) {
                                        data.aaData.push({
                                            "id": item.id,
                                            "kioskName": item.kioskName,
                                            "total": item.total,
                                            "transactionTimestamp": moment.utc(item.transactionTimestamp).format("DD-MM-YY HH:mm:ss"),
                                            "serviceType": item.serviceType,
                                            "paymentType": item.paymentType, //remove later in SP
                                            "paymentRecordID": item.paymentRecordID
                                        });
                                    });

                                    table = $('#tblCashRecord').DataTable({
                                        "paging": false,
                                        "ordering": false,
                                        "bAutoWidth": false,
                                        "bSortable": false,
                                        "bFilter": false,
                                        "bInfo": false,
                                        dom: 'Blfrtip',
                                        "aaData": data.aaData,
                                        "aaColumns": [
                                            { "mData": "kioskName" },
                                            { "mData": "serviceType" },
                                            { "mData": "transactionTimestamp" },
                                            { "mData": "total" }
                                        ]
                                    });

                                    $('#tblCashRecord tbody tr').each(function () {
                                        var col = $(this).find('td:eq(3)').html();
                                        total += parseFloat(col);
                                    });

                                    $('#totalAmount').html(total.toFixed(2));
                                    $('.sorting_asc').removeClass('sorting_asc');
                                }
                                else {
                                    $('#tblCashRecord').dataTable().fnClearTable();
                                    $('#tblCashRecord').dataTable().fnDestroy();

                                    $('#tblCashRecord').dataTable({
                                        "paging": false,
                                        "ordering": false,
                                        "bAutoWidth": false,
                                        "bSortable": false,
                                        "bFilter": false,
                                        "bInfo": false,
                                        "oLanguage": {
                                            "sEmptyTable": "No Record Found."
                                        }
                                    });
                                    $('#totalAmount').html("");
                                    $('.sorting_asc').removeClass('sorting_asc');
                                }
                            }
                            else {
                                $('#tblCashRecord').dataTable().fnClearTable();
                                $('#tblCashRecord').dataTable().fnDestroy();

                                $('#tblCashRecord').dataTable({
                                    "paging": false,
                                    "ordering": false,
                                    "bAutoWidth": false,
                                    "bSortable": false,
                                    "bFilter": false,
                                    "bInfo": false,
                                    "oLanguage": {
                                        "sEmptyTable": "Error: Could not load data."
                                    }
                                });
                                $('#totalAmount').html("");
                                $('.sorting_asc').removeClass('sorting_asc');
                            }
                        }
                    });

我的网络服务:

cashPaymentResponse IReport.GetCashPaymentRecord(string session, string reference, cashPaymentRequest request)
        {
            Guid sessionID, referenceID, kioskID;
            Guid.TryParse(session, out sessionID);
            Guid.TryParse(reference, out referenceID);
            Guid.TryParse(request.kioskID, out kioskID);

            if (sessionID == Guid.Empty)
            {
                return new cashPaymentResponse("Invalid Session.");
            }

            DateTime startDate, endDate;

            try
            {
                startDate = new DateTime(Convert.ToInt32(request.startDate.Substring(6, 4)), Convert.ToInt32(request.startDate.Substring(3, 2)), Convert.ToInt32(request.startDate.Substring(0, 2)), 0, 0, 0);

                endDate = new DateTime(Convert.ToInt32(request.endDate.Substring(6, 4)), Convert.ToInt32(request.endDate.Substring(3, 2)), Convert.ToInt32(request.endDate.Substring(0, 2)), 23, 59, 59);
            }
            catch (Exception ex)
            {
                return new cashPaymentResponse("No Date Selected.");
            }

            List<ReportCashPaymentRecord_Result> result;
            try
            {
                using (MyDBEntities context = new MyDBEntities())
                {
                    result = context.ReportCashPaymentRecord(sessionID, kioskID, startDate, endDate).ToList();
                }
            }
            catch (Exception ex)
            {
                if (isDebug() == false)
                {
                    return new cashPaymentResponse("Database connection failed.");
                }
                else
                {
                    return new cashPaymentResponse(ex.Message);
                }
            }

            if (result.Count > 0)
            {
                cashPaymentResponse response = new cashPaymentResponse();
                cashPaymentItem item;
                response.cashPayment = new List<cashPaymentItem>();

                for (int i = 0; i < result.Count; i++)
                {
                    item = new cashPaymentItem();

                    if (result[i].kioskName == "session")
                    {
                        return new cashPaymentResponse("Invalid Session.");
                    }
                    else
                    {
                        item.id = (Guid)result[i].cashID;
                        item.paymentRecordID = (Guid)result[i].paymentRecordID;
                        item.total = (decimal)result[i].total;
                        item.transactionTimestamp = JsonConvert.SerializeObject(new DateTime(result[i].transactiontimestamp.Value.Year, result[i].transactiontimestamp.Value.Month, result[i].transactiontimestamp.Value.Day, result[i].transactiontimestamp.Value.Hour, result[i].transactiontimestamp.Value.Minute, result[i].transactiontimestamp.Value.Second, 0, DateTimeKind.Utc)).Replace("\"", "");
                        item.kioskName = result[i].kioskName;
                        item.serviceType = (result[i].serviceType.ToString() == "0") ? "Assessment" : (result[i].serviceType.ToString() == "1") ? "Water Bill" : (result[i].serviceType.ToString() == "2") ? "Rental" : (result[i].serviceType.ToString() == "3") ? "Compound" : "None";
                        item.paymentType = (result[i].paymentType.ToString() == "1") ? "Cash" : (result[i].paymentType.ToString() == "3") ? "Credit Card" : (result[i].paymentType.ToString() == "2") ? "Cheque" : "None";

                        response.cashPayment.Add(item);
                    }
                }
                return response;
            }
            else
            {
                return new cashPaymentResponse();
            }
        }

我的JSON响应(实际上有8个条目,但我只包括第一个以减少混乱的条目):

My JSON Response (there are actually 8 entries, but I included only the first one to reduce clutter):

{
    "success": true,
    "cashPayment": [
        {
            "id": "xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx",
            "kioskName": "00001",
            "paymentRecordID": "yyyyyyyy-yyyy-yyyy-yyyy-yyyyyyyyyyyy",
            "paymentType": "Cash",
            "serviceType": "Water Bill",
            "total": 100,
            "transactionTimestamp": "2016-01-21T10:15:21Z"
        }
    ]
}

我已经在上面的响应中编辑了GUID,以删除敏感信息.

I have edited the GUIDs in the response above to remove sensitive information.

推荐答案

经典的匈牙利符号拼写错误. aaColumns应该为aoColumns-对于 a rray o 对象.然后,我相信它会起作用. aoColumns是1.10.x版本的BTW,现在称为columns(但仍支持两个名称).

Classic hungarian notation typo. aaColumns should be aoColumns - for array object. Then I am sure it will work. aoColumns is BTW from 1.10.x now called columns (but both names is still supported).

通常,使用新的1.10.x camelcase命名约定,请跳过所有在文字名称周围的内容:

In general, use the new 1.10.x camelcase naming convention and please skip all that qouting around literal names :

table = $('#tblCashRecord').DataTable({
  paging: false,
  ordering: false,
  autoWidth: false,
  sortable: false,
  filter: false,
  info: false,
  dom: 'Blfrtip',
  data: data.aaData,
  columns: [
    { data: "kioskName" }, 
    { data: "serviceType" }, 
    { data: "transactionTimestamp" },
    { data: "total" }
  ]
});


每个评论

更新.纠正"aaColumn"后,单元格为空的原因是您使用$.each的方式错误:


Update per comment. The reason for empty cells, after you have corrected "aaColumn", is that you are using $.each the wrong way :

$.each(response.cashPayment, function (item) {

应该是

$.each(response.cashPayment, function (index, item) { //<----
    data.aaData.push({
      "id": item.id,

您不小心尝试将属性而不是对象移出索引.

You are accidently trying to take the attributes out of the index, not the object.

这篇关于DataTables警告-为第0行第0列请求未知参数'0'的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆