A]问题摘要:
使用javascript函数生成jquery datatable的数据,该函数解析python返回的JSON数据。 浏览器中的结果HTML表格显示正确,但jquery数据表无法识别数据,并且数据表功能无法正常工作。当我查看HTML页面源代码时,我无法在表格中看到数据。
B]代码摘录:
1)jQuery数据表设置:
/* Define two custom functions (asc and desc) for string sorting */
jQuery.fn.dataTableExt.oSort['string-case-asc'] = function(x,y) {
return ((x < y) ? -1 : ((x > y) ? 1 : 0));
};
jQuery.fn.dataTableExt.oSort['string-case-desc'] = function(x,y) {
return ((x < y) ? 1 : ((x > y) ? -1 : 0));
};
$(document).ready(function() {
$('#datatable_for_current_users').dataTable( {
"aaSorting": [ [3,'desc'] ],
"aoColumns": [
null,
null,
{ "sType": 'string-case' },
null
]
});
});
2)jQuery数据表的HTML表格设置:
<div id="your_city">
<!-- Table containing the data to be printed-->
<table cellpadding="0" cellspacing="0" border="0" class="display" id="datatable_for_current_users">
<thead>
<tr>
<th>Country</th>
<th>City</th>
<th>Status</th>
<th>Reported at</th>
</tr>
</thead>
<tbody>
<!-- contents of the tbody will be loaded by javascript method XXX -->
</tbody>
</table>
</div>
3)解析从python返回的JSON输出的Javascript,并填充数据表的“tbody”:
这里javascript将用户国家和城市发送给python代码。 Python代码然后找出特定用户的数据库对象,并将JSON数据发送回javascript。
$.post("/AjaxRequest", {
selected_country_name: $users_country,
selected_city_name: $users_city
},
function LoadUsersDatatable(data) {
var tbody = $("#datatable_for_current_users > tbody").html("");
jsonData = jQuery.parseJSON(data);
for (var i = 0; i < jsonData.length; i++) {
var citydata = jsonData[i];
var rowText = "<tr class='gradeA'><td>" + citydata.city.country.country_name + "</td><td>" + citydata.city.city_name + "</td><td>" + citydata.status + "</td><td>" + citydata.date_time.ctime + "</td></tr>";
$(rowText).appendTo(tbody);
}
}
);
4)渲染HTML页面时,我检查数据表的“tbody”,它是空的:
<tbody>
<!-- contents of the tbody will be loaded by javascript method XXX -->
</tbody>
对我而言,这似乎是问题
然而,在浏览器中,我看到表格正确加载,但数据表显示0条目,搜索排序功能清空表格
答案 0 :(得分:1)
您必须使用DataTables fnAddData
方法来获取新行,而不是简单地将原始html附加到表正文中。
所以对你来说,你的代码看起来像这样
var dt = $('#datatable_for_current_users').dataTable();
....
dt.fnAddData({DT_RowClass: 'gradeA', 0: citydata.city.country.country_name, 1: citydata.city.city_name, 2: citydata.status, 3: citydata.date_time.ctime}, true);
最后true
只需在添加行后重绘表格。如果需要,您可以将其更改为false
并在完成循环后调用dt.fnDraw();
以立即添加所有行