Telerik MVC 网格 - 使用下拉列表更新"Uneditable"字段



当我使用内联下拉列表拉取其中一个字段时,我有一个网格集。

我可以从下拉列表数据项中检索所需的值,并且可以使用下拉列表在网格的编辑行中设置值。

只要 A、B、C 和 D 是可编辑的,以下代码就可以正常工作...但。。。这些值不应是可编辑的。 这些单元格中的值应严格由下拉列表的值驱动。

function ddl_OnSelect(e)
{
    var DDLdataItem = this.dataItem(e.item);
    var A = DDLdataItem.A;
    var B = DDLdataItem.B;
    var C = DDLdataItem.C;
    var D = DDLdataItem.D;
    var grid = $('#grd').data('kendoGrid');
    var editRow = grid.dataItem("tr.k-grid-edit-row");

    editRow.set("A", DDLdataItem.A);
    editRow.set("B", DDLdataItem.B);
    editRow.set("C", DDLdataItem.C);
    editRow.set("D", DDLdataItem.D);
}

我觉得我应该能够在模板列中显示值,但我在 column.template 上找不到任何好的文档,当我做这样的事情时,它只会给我一个空列。

        columns.Template(
            @<text>
                <input type="text" name="A" value="@item.A" readonly />
            </text>
                 ).Title("A");

更新

还行。。。。所以我为"解决"这个问题所做的是......

首先,我创建了一个名为 ReadOnlyCurrency 的新编辑器模板,并将其放置在共享的 EditorTemplates 中。

然后,对于适用于的 3 个货币列中的每一个,我添加了编辑器模板名称属性。

.EditorTemplateName("ReadOnlyCurrency")

然后,我复制了货币编辑器模板的内容并将其粘贴到只读货币模板中

我关闭了微调器,使其只读,并使其启用 false。

@model decimal?
@(Html.Kendo().CurrencyTextBoxFor(m => m)
      .HtmlAttributes(new { style = "width:100%;", @readonly = "readonly" })
      .Enable(false)
      .Min(0)
      .Spinners(false)
)

这对于我正在尝试做的事情已经足够了,但我不会将其标记为答案。

我宁愿有一个格式化为货币的标签......但是我对编辑器模板在模型中传递的方式有问题。

在 telerik 社区的帮助下,我找到了更好的解决方案。

首先,我们将模型中的字段保留为可编辑:

model.Field(p => p.A);
model.Field(p => p.B);
model.Field(p => p.C);

然后在列绑定中,我们将可编辑设置为始终返回 false 的函数:

columns.Bound(p => p.A).Title("A").Editable("editable").ClientTemplate("<span class='A'>#: kendo.toString(A, 'C') #</span>").ClientFooterTemplate("#= kendo.toString(sum, 'C') #");
columns.Bound(p => p.B).Title("B").Editable("editable").ClientTemplate("<span class='B'>#: kendo.toString(B, 'C') #</span>").ClientFooterTemplate("#= kendo.toString(sum, 'C') #");
columns.Bound(p => p.C).Title("Total").Editable("editable").ClientTemplate("<span class='C'>#: kendo.toString(C, 'C') #</span>").ClientFooterTemplate("#= kendo.toString(sum, 'C') #");

然后在 change 函数中,我们在 dataItem 中设置值,并在 clientRow 中设置客户端值。

var editRow = $("tr.k-grid-edit-row").closest("[data-role=grid]").data("kendoGrid").dataItem("tr.k-grid-edit-row");
var clientRow = $("tr.k-grid-edit-row");
editRow.set("A", this.dataItem(e.item).A);
editRow.set("B", this.dataItem(e.item).B);
editRow.set("C", this.dataItem(e.item).C);
clientRow.find(".A").text(kendo.toString(this.dataItem(e.item).A, 'C'));
clientRow.find(".B").text(kendo.toString(this.dataItem(e.item).B, 'C'));
clientRow.find(".C").text(kendo.toString(this.dataItem(e.item).C, 'C'));

到目前为止,这为我提供了我一直在寻找的功能。

最新更新