数据表 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