kendoUI,如何在kendo网格上进行批量内联编辑时添加回调函数

时间:2013-02-26 16:01:52

标签: kendo-ui kendo-treeview

这是我使用aspl.net mvc包装器的kendo网格。问题是当您进行批量内联编辑时。然后点击保存。

.Create(create => create.Action("UpdateLiabilities", "Liability", parameters))
将触发

并将所有更改保存到数据库中。现在我需要添加一个回调函数来显示帐户成功添加的消息。我不知道如何添加这个回调函数。

@(Html.Kendo().Grid<LiabilityVM>()
  .Name("QualifiedNonrecourseDebtGrid")
  .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 #")
                       .ClientTemplate("<span style='white-space:nowrap'><a href='\\#' onclick=\"showAccountInfo('acctInfoPopupContainer', " + parameters.clientId + ", " + parameters.projectId + ",#=WorkpaperId#, #=AccountId#, '#=AccountNumber#', '#=AccountNumberAndDescAndLabel#')\"> #= AccountNumber # </a></span>")
                       .HtmlAttributes(new { nowrap = "nowrap" })
                       .Width(70);
                   columns.Bound(i => i.Description)
                       .Title("Description")
                       .ClientTemplate("<span href='\\#' title='#= getEncodedValueOrDefault(Description, '')#'  style='white-space:nowrap'>#= getHtmlEncode(Description, '') #</span>")
                       .HtmlAttributes(new { nowrap = "nowrap" })
                       .Width(120);


               })
      .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);
                              })
                              .ServerOperation(true).Group(groups => groups.Add(p => p.Source))
                              .Create(create => create.Action("UpdateLiabilities", "Liability", parameters))
                              .Read(read => read.Action("GetLiabilities", "Liability", parameters))
                              .Update(update => update.Action("UpdateLiabilities", "Liability", 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()
  )

2 个答案:

答案 0 :(得分:4)

此活动有一个特殊事件,名为 sync

在你的情况下它应该是这样的:

 .DataSource(grid => grid.Ajax().Events(ev=>ev.Sync("theNameOfTHeCallBackFUnction")))

答案 1 :(得分:0)

在您的UpdateLiability方法中

返回jsonp而不是json(JavaScriptResult)为

 const string alertMessage = "created";
 string aMessage = string.Format("alert('{0}');", alertMessage);
 var returned = new JavaScriptResult { Script = aMessage };
 return returned;
相关问题