jquery.dataTables
およびknockout js
を使用して、データをテーブルにバインドしています。jquery.dataTablesを使用してobservableArrayからアイテムを削除した後にUIが更新されない
observableArray
からアイテムを削除すると、UIは更新されません。私はjquery.Datatable
にデータをバインドするので、テーブルを再初期化することができます。だからTableManaged.init();
メソッドを呼び出してテーブルを再初期化しますが、警告cannot reinitialise datatable
を生成しています。
以下は私のコードです。ここで
function PatientVM(vm) {
self.MDSPatientId = ko.observable(vm.MDSPatientId());
self.PatientNumber = ko.observable(vm.PatientNumber());
self.PrescribingDay = ko.observable(vm.PrescribingDay());
self.OneWeekItems = ko.observable(vm.OneWeekItems());
self.DeliveryDay = ko.observable(vm.DeliveryDay());
self.IsActive = ko.observable(vm.IsActive());
self.WeekColor = ko.observable(vm.WeekColor());
self.PatientName = ko.observable(vm.PatientName());
self.FullAddress = ko.observable(vm.FullAddress());
}
function Patients(vm) {
var self = this;
self.PatientList = ko.observableArray();
if (vm.PatientList() != null) {
for (i = 0; i < vm.PatientList().length; i++) {
var p = new PatientVM(vm.PatientList()[i]);
self.PatientList.push(p);
}
}
self.DeletePatient = function(patient) {
var result = confirm("Want to delete?");
if (result) {
$.ajax({
url: '@Url.Action("DeleteMDSPatient", "Patient")',
cache: false,
type: 'GET',
contentType: "application/json; charset=utf-8",
dataType: "json",
data: {
'MDSPatientId': patient.MDSPatientId()
},
success: function(response) {
if (response.Result == 3) {
self.PatientList.remove(patient);
ShowToastMessage("Patient has been deleted successfully", "Success", true);
}
},
error: function(errorThrown) {}
});
}
}
}
$(document).ready(function() {
ko.applyBindings(new Patients(ko.mapping.fromJS(@Html.Raw(JsonConvert.SerializeObject(Model)))));
App.init();
TableManaged.init();
});
<table class="table table-striped table-bordered table-hover" id="sample_3" style="line-height:22px;table-layout:fixed;overflow-x:hidden;">
<thead>
<tr style="background-color:#348fe2">
<th style="width:5%;text-align:center">
<span class="showellipses">Active Patient</span>
</th>
<th style="width:10%"><span>Name</span>
</th>
<th style="width:20%"><span class="showellipses">Address</span>
</th>
<th style="width:10%"><span class="showellipses">PrescribingDay</span>
</th>
<th style="width:5%"><span class="showellipses">No. of items in four week</span>
</th>
<th style="width:10%"><span class="showellipses">Assembly Week</span>
</th>
<th style="width:10%"><span>Delivery Day</span>
</th>
<th style="width:5%">Action</th>
</tr>
</thead>
<tbody data-bind="foreach:PatientList">
<tr class="odd gradeX">
<td style="text-align:center">
<input type="checkbox" data-bind="checked:IsActive, click:ChangePatientStatus" class="checkboxes" />
</td>
<td>
<span class="showellipses" data-bind="text:PatientName"></span>
</td>
<td>
<span class="showellipses" data-bind="text:FullAddress"></span>
</td>
<td>
<span data-bind="text:PrescribingDay"></span>
</td>
<td class="center">
<span data-bind="text:OneWeekItems"></span>
</td>
<td>
<span data-bind="text:WeekColor"></span>
</td>
<td>
<span data-bind="text:DeliveryDay"></span>
</td>
<td>
<a title="Edit" style="text-decoration:none" class="fa fa-edit" data-bind="attr: { 'href': '@Url.Action(" PatientView ", "Patient ")?MDSPatientId=' + MDSPatientId()}"></a> |
<a title="Delete" style="text-decoration:none" class="fa fa-trash-o" data-bind="click:$parent.DeletePatient"></a>
</td>
</tr>
</tbody>
</table>
テーブルをレンダリングするためにノックアウトを実際に使いたい場合は、Think * very * hardと思ってください。 DataTablesは独自の非常に強力なテーブルレンダリングエンジンを備えており、絶対に使用する必要があります。 DataTablesとノックアウト機能は、この場合重複し重複しています。お互いにうまくプレイさせることは容易ではありません。ページのこの部分にライブラリのうちの1つだけを使用することは賢明でしょう。そして、DataTablesだけを使用することは、他の方法よりもずっと簡単になります。 – Tomalak