对我来说,正在创建新行,但有些值是错误的。
我的jQuery DataTables列表:
$.ajax({
url: '@Url.Action("LoadEventChargesByUtility", "Vendor")',
contentType: "application/json; charset=utf-8",
datatype: "json",
data: "{'stayiD':'" + stayi + "','datetime':'" + datetime + "','Groupid':'" + Groupid + "'}",
type: "POST", // 'GET' or 'POST' ('GET' is the default)
success: function (data) {
data = JSON.parse(data);
if (data != "No Items") {
$('#tblevent').dataTable({
"sPaginationType": "full_numbers",
"aaData": data,
"bAutoWidth": false,
"bDeferRender": true,
"destroy": true,
"aoColumns": [
{ "mData": "SERVICETEXT", 'sTitle': 'Service Name' },
{ "mData": "ITEMNAME", 'sTitle': 'Item Name' },
{ "mData": "USGDATE", 'sTitle': 'Usage Date', 'bSortable': false, 'bSearchable': false, 'mRender': function (data, type, full) {
return moment(data).format('DD/MM/YYYY');
}
},
//{
// "mData": "INSDATE", 'sTitle': 'Insert Date', 'bSortable': false, 'bSearchable': false, 'mRender': function (data, type, full) {
// return moment(data).format('ll');
// }
//},
{ "mData": "QUANTITY", 'sTitle': 'Quantity' },
{ "mData": "UNITTEXT", 'sTitle': 'Unit' },
{ "mData": "RATE", 'sTitle': 'RATE' },
{ "mData": "AMOUNT", 'sTitle': 'AMOUNT' },
{ "mData": "SID", 'sTitle': 'Edit', 'bSortable': false, 'bSearchable': false, 'mRender': function (data, type, full) {
//return ' <div class="hidden-sm hidden-xs action-buttons"><a class="green" href="#"><i class="ace-icon fa fa-pencil bigger-130" onclick="return GetServicecharge(\'' + data + '\');"></i></a></div>';
return ' <div class="hidden-sm hidden-xs action-buttons"><a class="green" href="#"><i class="ace-icon fa fa-pencil bigger-130" onclick="return EditEventDetails(this);"></i></a></div>';
}
}
]
});
$('#EventDeatils').modal();
}
else {
$('#tblevent >thead').remove();
$('#tblevent >tbody').remove();
var tr = '<tr><td>No Records</td></tr>';
$('#tblevent >tbody').remove();
$('#tblevent').append(tr);
}
},
error: function (xhr, status, error) {
var err = eval("(" + xhr.responseText + ")");
alert(err.Message);
}
});
在该使用日期USGDATE
和上次修改SID
无效。它在我创建新行时显示默认值。
我的新行添加如下:
var t = $('#tblevent').DataTable();
t.row.add({
"SERVICETEXT": "<td >service</td>",
"ITEMNAME": "<td>item</td>",
"USGDATE": "<td>date</td>",
"QUANTITY": "<td><input type=\"text\" class=\"txtDtEdit\" style=\"width: 52px;\" value=\"\" /></td>",
"UNITTEXT": "<td><select id=\"ddlupdateunit\" style=\"width: 73px;\" ></select></td>",
"RATE": "<td><input type=\"text\" class=\"txtDtEdit\" style=\"width: 52px;\" value=\"\" /></td>",
"AMOUNT": "<td><input type=\"text\" class=\"txtDtEdit\" style=\"width: 52px;\" value=\"\" /></td>",
"SID": "<td style=\"width:80px\"><div class=\"hidden-sm hidden-xs action-buttons\"><a class=\"green\" href=\"#\"><i class=\"ace-icon fa fa-check bigger-120\" onclick=\"return updateRowData(this);\"></i></a></div></td>"
}).draw().node();
需要出现最后SID
个详细信息,但似乎有误。如果我触发此功能,则会在中间添加新行,并且需要在顶部添加此新行。
我的HTML:
<table id="tblevent" class="table table-condensed table-hover table-striped table-bordered">
</table>
需要更改三个细节:
SID
需要更改答案 0 :(得分:1)
您应该添加实际数据而不是<td></td>
元素。例如,
var t = $('#tblevent').DataTable();
t.row.add({
"SERVICETEXT": "Service Name",
"ITEMNAME": "Item name",
"USGDATE": "1995-12-25",
"QUANTITY": "1",
"UNITTEXT": "2",
"RATE": "3",
"AMOUNT": "4",
"SID": "5"
}).draw();
要在单元格中呈现单元格内容并显示<input>
元素,请对这些列使用mRender
回调,类似于将其用于SID
列的方式。