Javascript 向数据表动态添加数据
我目前正在用Python编写一个爬虫程序。此爬虫程序正在mongoDB数据库中存储数据。我希望将数据动态加载到表中,而不必重新加载整个页面 我当前的(相关)代码如下所示:Javascript 向数据表动态添加数据,javascript,json,datatables,Javascript,Json,Datatables,我目前正在用Python编写一个爬虫程序。此爬虫程序正在mongoDB数据库中存储数据。我希望将数据动态加载到表中,而不必重新加载整个页面 我当前的(相关)代码如下所示: var $tagsLabel = $("<lable>") var $tagsInput = $("<textarea>"); /* Formatting function for row details - modify as you need */ function format(d) {
var $tagsLabel = $("<lable>")
var $tagsInput = $("<textarea>");
/* Formatting function for row details - modify as you need */
function format(d) {
// `d` is the original data object for the row
return '<table cellpadding="5" cellspacing="0" border="0" style="padding-left:50px;">' +
'<tr>' +
'<td>Raw text:</td>' +
'<td>' + d.Raw_html + '</td>' +
'</tr>' +
'</table>';
}
$(document).ready(function () {
$table = $("#dataTable")
.on("preInit.dt", function (e, settings) {
$tagsLabel.append($tagsInput);
$('.dataTables_tags').append($tagsLabel)
})
.on("init.dt", function (e, settings) {
$tagsInput.tagEditor({
delimiter: ', ',
placeholder: 'Enter search tags ...',
onChange: function (field, editor, tags) {
if (tags.length) {
if (tags.length > 1) {
$table.search(tags.join('|'), true, false).draw();
} else {
$table.search(tags[0]).draw();
}
} else {
$table.search('').draw(true);
}
},
});
})
.DataTable({
"dom": '<l<"dataTables_tags"><t>ip>',
"ajax": '/json-int',
"columns": [
{
"class": 'details-control',
"orderable": false,
"data": null,
"defaultContent": '',
width: "5px"
},
{"data": "Timestamp", width: "135px"},
{"data": "Title"},
{"data": "Url"},
{"data": "domain"},
{"data": "Type"},
{"data": "Raw_html", "visible": false}
//{"data": "Raw_html", "visible": false}
],
"order": [[1, 'asc']]
});
// Add event listener for opening and closing details
$('#dataTable tbody').on('click', 'td', function () {
var tr = $(this).closest('tr');
var row = $table.row(tr);
if (row.child.isShown()) {
// This row is already open - close it
row.child.hide();
tr.removeClass('shown');
} else {
// Open this row
row.child(format(row.data()), 'no-padding').show();
tr.addClass('shown');
}
});
$('#dataTable tbody').on('click', 'td > button', function (e) {
alert('Tada!');
return false;
});
});
<table id="dataTable" class="table table-striped table-hover table-bordered table-condensed"
style="width: 100%; font-size: 12px" role="grid">
<thead>
<tr>
<th></th>
<th>Timestamp</th>
<th>Title</th>
<th>URL</th>
<th>Domain</th>
<th>Page Type</th>
</tr>
</thead>
<tfoot>
<tr>
<th></th>
<th>Timestamp</th>
<th>Title</th>
<th>URL</th>
<th>Domain</th>
<th>Page Type</th>
</tr>
</tfoot>
</table>
该表加载良好,如果我重新加载整个页面,数据将加载到DataTable中。每次运行函数动态更新表时,我都会收到以下错误:
DataTables警告:表id=dataTable-为第0行第1列请求的未知参数“Timestamp”。有关此错误的详细信息,请参阅
我发布了一个我试图动态加载到表中的数据示例:
希望有人能给我指出正确的方向
编辑:
对不起,也许我对这个问题描述得不够清楚。当我加载页面时,数据被加载。但我希望在有新数据时向表中添加新行。每次请求时,/json都会提供这些新数据。你不需要发明自己的自行车,它已经存在了。 您只需使用相应的参数扩展DataTable初始化:
var t = $('#dataTable').DataTable({
ajax: '/url/to/script/feeding/data',
...
});
你不需要发明你自己的自行车,它已经存在了。 您只需使用相应的参数扩展DataTable初始化:
var t = $('#dataTable').DataTable({
ajax: '/url/to/script/feeding/data',
...
});
对不起,也许我对这个问题描述得不够清楚。当我加载页面时,数据被加载。但我希望在有新数据时向表中添加新行。每次请求时,/json都会提供这些新数据。对不起,可能我对这个问题描述得不够清楚。当我加载页面时,数据被加载。但我希望在有新数据时向表中添加新行。每次请求/json时,它都会提供这个新数据。这正是我当前在页面加载中加载数据所做的。但是我想向表中添加包含新数据的新行。我已经将此添加到问题中。要从源代码更新数据,只需调用ajax.reload()方法,这正是我当前在页面加载时加载数据所做的。但是我想向表中添加包含新数据的新行。我已经将此添加到问题中。要从源代码更新数据,只需调用ajax.reload()方法