开发者问题收集

数据表 AJAX 请求-未知长度

2017-04-11
221

一段时间以来,我一直在为此苦苦挣扎。尝试填充我的数据表,但遇到了以下错误:

Uncaught TypeError: Cannot read property 'length' of undefined
    at jquery.dataTables.min.js:48
    at i (jquery.dataTables.min.js:35)
    at Object.success (jquery.dataTables.min.js:35)
    at i (jquery-3.1.1.min.js:2)
    at Object.fireWith [as resolveWith] (jquery-3.1.1.min.js:2)
    at A (jquery-3.1.1.min.js:4)
    at XMLHttpRequest.<anonymous> (jquery-3.1.1.min.js:4)

据我所知,所有内容都格式正确,因此我一定遗漏了某些内容。有什么问题吗?

这是我的 HTML 示例

<table id="myGrid" class="table">
                    <thead>
                        <tr>
                            <th>CarPrefix</th>
                            <th>CarNumber</th>
                            <th>CarDesc</th>
                            <th>CarScreenDesc</th>
                            <th>CarSummaryDesc</th>
                            <th>CarColorDesc</th>
                            <th>CarCodeComputed</th>
                            <th>CarStatusDesc</th>
                        </tr>
                    </thead>   

这是我的 ajax 请求:

$('#myGrid').DataTable({
        ajax: '/populatecardata',
        dataSrc: 'data',
        columns: [
            { data:"CarPrefix" },
            { data: "CarNumber" },
            { data: "CarDesc" },
            { data: "CarScreenDesc" },
            { data: "CarSummaryDesc" },
            { data: "CarColorDesc" },
            { data: "CarCodeComputed" },
            { data: "CarStatusDesc" }
        ]
    });

我的控制器

Route("populatecardata"), HttpGet]

        public object getTableData()
        {

                using (CarEntities ce = new CarEntities())
                {

                PopulateData pd = new PopulateData();
                var resultsList = pd.GetTableData(ce);             
                return resultsList;

                }


        }

以及我的数据提取方法:

public object GetTableData(CarEntities ce)
        {
                Data ltr = new Data();
                resultsList = ce.CarData.Take(1).ToList();
                foreach(var result in resultsList)
            {
                TableResults tr = new TableResults();
                tr.CarPrefix = result.CarPrefix;
                tr.CarNumber = result.CarNumber;
                tr.CarDesc = result.CarDesc;
                tr.CarScreenDesc = result.CarScreenDesc;
                tr.CarSummaryDesc = result.CarSummaryDesc;
                tr.CarColorDesc = result.CarColorDesc;
                tr.CarCodeComputed = result.CarCodeComputed;
                tr.CarStatusDesc = result.CarStatusDesc;
                tr.CarStatusDesc = "TestStatus";
                ltr.jsondata.Add(tr);

            }
            var jsonObject = JsonConvert.SerializeObject(ltr);
            return jsonObject;

        }

        public class Data
        {
            [JsonProperty("data")]
            public List<TableResults> jsondata { get; set; }
            public Data()
            {
                jsondata = new List<TableResults>();
            }
        }




        public class TableResults
        {
            [JsonProperty("CarPrefix")]
            public string CarPrefix { get; set; }

            [JsonProperty("CarNumber")]
            public string CarNumber { get; set; }

            [JsonProperty("CarDesc")]
            public string CarDesc { get; set; }

            [JsonProperty("CarScreenDesc")]
            public string CarScreenDesc { get; set; }

            [JsonProperty("CarSummaryDesc")]
            public string CarSummaryDesc { get; set; }

            [JsonProperty("CarColorDesc")]
            public string CarColorDesc { get; set; }

            [JsonProperty("CarCodeComputed")]
            public string CarCodeComputed { get; set; }

            [JsonProperty("CarStatusDesc")]
            public string CarStatusDesc { get; set; }


        }
    }

以及 JSON 对象示例:

{
    "data": [
        {
            "CarPrefix": "ty",
            "CarNumber": "1009",
            "CarDesc": "Toyota 2009 4Cylinder FWD",
            "CarScreenDesc": "4CY-Toyota",
            "CarSummaryDesc": "Toyota 2009",
            "CarColorDesc": "Red",
            "CarCodeComputed": "ty1009",
            "CarStatusDesc": "Available"
        }
    ]
}
2个回答

如果您知道如何在 Chrome 或 IE 调试器中使用调试器命令,您可以按照以下方式操作,以更好地了解问题所在:

$('#myGrid').DataTable({
    ajax:{
        url: '/populatecardata',
        dataFilter: function(dtData) {
            debugger;
            console.log(dtData);
            return dtData;
        },
        error: function(err, status){
            debugger;
            console.log(err);
         }

     },
columns: [
    { data:"CarPrefix" },
    { data: "CarNumber" },
    { data: "CarDesc" },
    { data: "CarScreenDesc" },
    { data: "CarSummaryDesc" },
    { data: "CarColorDesc" },
    { data: "CarCodeComputed" },
    { data: "CarStatusDesc" }
]
});    
Bindrid
2017-04-12

您的 DataTable 语法有点不对。

$('#myGrid').DataTable({
    ajax:{url: '/populatecardata',
          dataSrc: 'data'},
    columns: [
        { data:"CarPrefix" },
        { data: "CarNumber" },
        { data: "CarDesc" },
        { data: "CarScreenDesc" },
        { data: "CarSummaryDesc" },
        { data: "CarColorDesc" },
        { data: "CarCodeComputed" },
        { data: "CarStatusDesc" }
    ]
});

但是,dataSrc 默认值为“data”,因此您实际上可以删除它并使用

$('#myGrid').DataTable({
    ajax: '/populatecardata',

    columns: [
        { data:"CarPrefix" },
        { data: "CarNumber" },
        { data: "CarDesc" },
        { data: "CarScreenDesc" },
        { data: "CarSummaryDesc" },
        { data: "CarColorDesc" },
        { data: "CarCodeComputed" },
        { data: "CarStatusDesc" }
    ]
});
Bindrid
2017-04-12