私は編集ボタンを持っており、剣道グリッドでは、連続して何かを変更すると発生する onSave イベントがあります。行を更新するときに dataItem 値にアクセスしたいのですが、何らかの理由で常に null です。何が間違っていますか? ドロップダウンメニューの値に問題なくアクセスできますが、非表示の値も必要です。
JS
function onSave(e) {
if (e.model.StatusIdD) {
e.model.StatusIdD = 0;
var currentlySelectedValue = $(e.container).find('#StatusIdD').data("kendoDropDownList").value();
var dataItem = this.dataItem($(e.target).closest("tr"));
var bojaTeksta = dataItem.BojaTeksta;
console.log(bojaTeksta);
e.model.set('StatusIdD', currentlySelectedValue);
e.model.set('Status', $(e.container).find('#StatusIdD').data("kendoDropDownList").text());
//e.model.set('BojaPozadine', currentlySelectedValue);
//e.model.set('BojaTeksta', currentlySelectedValue);
}
}
グリッド - 簡略化
...
columns.Bound(p => p.BojaTeksta).Hidden(true);
columns.Bound(p => p.BojaPozadine).Hidden(true);
...
.Events(e => e.Remove("onRemove").Save("onSave"))
答え
dataItem ではなく selectedItem を使用してデータを取得できました (コマンド ボタンをクリックすると、自動的に行が選択されます)。
var grid = $("#Grid" + '@guid').data("kendoGrid");
var selectedItem = grid.dataItem(grid.select());
var bojaTeksta = selectedItem.BojaTeksta;
var bojaPozadine = selectedItem.BojaPozadine;
console.log(bojaTeksta);
console.log(bojaPozadine);