我怎样才能在剑道MVC网格中实现这一目标?

时间:2012-09-24 05:39:51

标签: asp.net-mvc-3 kendo-ui

我刚刚在我的MVC3项目中使用了Kendo UI Hierarchy Grid。层次结构大约有2个级别。我需要使用自己的自定义actionlink自定义第二级层次结构以添加详细信息。

执行流程很简单。 Kendo Grid将填充默认记录。如果用户选择查看任何记录的内部细节,则应显示另一个带有actionlink的层次结构网格,用于添加新记录。

这是我的孩子网格代码:

<script id="pordersTemplate" type="text/kendo-tmpl">

@Html.ActionLink("Create PoDetails", "Create", "PoDetails", new { id = "#=Id#" }, null)   
 // Here i need to get the current selected ID to use it on the create page.

    @(Html.Kendo().Grid<Models>()
        .Name("PoDetails_#=Id#")
        .Columns(columns =>
        {

            columns.Bound(o => o.Copies).Width(140).ClientTemplate(Html.ActionLink("\\#=Copies\\#", "Edit", "PoDetails", new { Id = "id" }, null).ToHtmlString().Replace("id", "\\#=Id\\#"));
            columns.Bound(o => o.Title).Width(150);
            columns.Bound(o => o.UnitPrice).Width(200);
            columns.Bound(o => o.Account).Width(200);
            columns.Bound(o => o.Status).Width(200);
            columns.Command(command => command.Destroy()).Width(110).Title("Action");
        })

        .DataSource(dataSource => dataSource
        .Ajax()
        .Read(read => read.Action("HierarchyBinding_PoDetails", "Porders", new { PoId = "#=Id#" }))
        .Batch(false)
        .ServerOperation(true)
        .Events(events => events.Error("error_handler"))
        .Model(model => model.Id(p => p.Id))
        .Destroy("Delete", "PoDetails")
        )
        .Pageable()
        .Sortable()
        .Groupable()
        .Filterable()
        .ToClientTemplate()
)

请告诉我一些建议,将此动作链接添加到网格中。

谢谢,

1 个答案:

答案 0 :(得分:1)

为什么不使用工具栏:

@(Html.Kendo().Grid<Models>()
    .Name("PoDetails_#=Id#")
    .Columns(columns =>
    {

        columns.Bound(o => o.Copies).Width(140).ClientTemplate(Html.ActionLink("\\#=Copies\\#", "Edit", "PoDetails", new { Id = "id" }, null).ToHtmlString().Replace("id", "\\#=Id\\#"));
        columns.Bound(o => o.Title).Width(150);
        columns.Bound(o => o.UnitPrice).Width(200);
        columns.Bound(o => o.Account).Width(200);
        columns.Bound(o => o.Status).Width(200);
        columns.Command(command => command.Destroy()).Width(110).Title("Action");
    })

    .ToolBar(t => t.Create().Text("Create PoDetails")) // <-- add here the toolbar

    .DataSource(dataSource => dataSource
        .Ajax()
        .Read(read => read.Action("HierarchyBinding_PoDetails", "Porders", new { PoId = "#=Id#" }))

        // and here map the create event with your custom action
        .Create(c => c.Action("Create", "PoDetails", new { id = "#=Id#" }))

        .Batch(false)
        .ServerOperation(true)
        .Events(events => events.Error("error_handler"))
        .Model(model => model.Id(p => p.Id))
        .Destroy("Delete", "PoDetails")
    )
    .Pageable()
    .Sortable()
    .Groupable()
    .Filterable()
    .ToClientTemplate()
)