剑道网格,为什么e.model.set不起作用



在我的剑道网格中,我有3列,平衡、调整和调整平衡。平差是平差和平差的总和。将对其进行计算。如果我更改调整字段。调整平衡应该自动改变。

我正在将保存事件绑定到网格。

$("#DebtGrid").data("kendoGrid").bind("save", onDebtGridEditComplete); 

function onDebtGridEditComplete(e) {
    debugger;
    var grid = $('#NonrecourseDebtGrid').data().kendoGrid;        
    var dataItem = e.model;
    e.model.set('TaxAdjustments', e.values.TaxAdjustments);
    var newBalance = getAdjBalance(dataItem.TaxBalance, e.values.TaxAdjustments);
    e.model.set('TaxAdjustmentBalance', newBalance);
    //grid.refresh();
}

我调试了下面的函数,我看到newBalance是计算出来的,在我设置了textadjustmentbalance之后。我检查了电子模型,没有任何变化。它仍然有旧的价值。

e.model.set('TaxAdjustmentBalance', newBalance);

这是我的格子。

@(Html.Kendo().Grid<LiabilityVM>()
  .Name("DebtGrid")
  .HtmlAttributes(new { style = "height: 300px;" })
  .Columns(columns =>
               {
                   columns.Bound(i => i.Id).Visible(false);
                   columns.Bound(i => i.AccountId).Visible(false);
                   columns.Bound(i => i.AccountNumber)
                       .Title("Account #")
                       .HtmlAttributes(new { nowrap = "nowrap" })
                       .Width(70);
                   columns.Bound(i => i.TaxBalance)
                       .Title("Balance")
                       .HtmlAttributes(textAlign)
                       .Width(70);
                   columns.Bound(i => i.TaxAdjustments)
                       .Title("Adjustments")
                       .EditorTemplateName("AmountEditor")
                       .HtmlAttributes(textAlign)
                       .Width(70)
                       .ClientFooterTemplate("<span><b> Total: </b></span>")
                       .FooterHtmlAttributes(textAlign);
                   columns.Bound(i => i.TaxAdjustmentBalance)
                       .Title("Adj. Balance")
                       .ClientTemplate("<span href='\#' style='white-space:nowrap'>#= TaxAdjustmentBalance #</span>")
                       .HtmlAttributes(textAlign)
                       .Width(70)
                       .ClientFooterTemplate("#= formatAmount(getTotalAdjBalance('NonrecourseDebtGrid'), '{0:c0}') #").FooterHtmlAttributes(textAlign);
                   columns.Bound(i => i.IsSuppressed)
                       .Title("Suppress")
                       .ClientTemplate("#= showCheckBox(IsSuppressed,Source, Id) #")
                            .Width(50)
                            .Sortable(false)
                            .Filterable(false);
               })
      .Editable(editable => editable.Mode(GridEditMode.InCell))
      .DataSource(grid => grid.Ajax()
                              .Batch(true)
                              .Model(model => { 
                                                model.Id(i => i.Id);
                                                model.Field(p => p.AccountNumber).Editable(false);
                                                model.Field(p => p.TaxBalance).Editable(false);
                                                model.Field(p => p.TaxAdjustmentBalance).Editable(false);
                              })
                              .ServerOperation(true)
                              .Create(create => create.Action("Update", "test", parameters))
                              .Read(read => read.Action("Get", "test", parameters))
                              .Update(update => update.Action("Update", "test", parameters))
                              .Aggregates(aggregates =>
                                         {
                                             aggregates.Add(p => p.TaxAdjustmentBalance).Sum();
                                         })
  )
  .Sortable()
  .Filterable()
  .Selectable(s => s.Mode(GridSelectionMode.Single))
  .Resizable(resize => resize.Columns(true))
  .Reorderable(reorder => reorder.Columns(true))
  .ColumnMenu()
  .Scrollable()
  )

发生这种情况是因为您已将字段设置为不可编辑。

model.Field(p => p.TaxAdjustmentBalance).Editable(false);

您可以尝试使字段可编辑,并创建只显示值的自定义编辑器,这样用户就无法编辑它。

最新更新