asp.net-mvcasp.net-mvc-4kendo-uikendo-gridclient-templates

kendoui ClientTemplate in Grid not working in asp.net mvc 4


I have been looking all over for the answer and think I am missing something simple. I have a kendo grid where I want one of the columns to be a link to another page with the id as a route parameter. However, the value in the column cells are the bound values and are unchanged by my template. Any insights to this will be appreciated.

@(Html.Kendo().Grid((IEnumerable<ProviderAccess>)Model.Providers)
.Name("grants-grid")
.Columns(columns =>
{
    columns.Bound(a => a.ProviderName);
    columns.Bound(a => a.HasAccess);
    columns.Bound(a => a.ProviderId).ClientTemplate("#= toggleLink(data) #");
})
.Scrollable()
)

<script>
function toggleLink(access) {
    var action = '@Url.Action("Toggle", "Access")';

    var html = kendo.format("<a href='{0}/{1}'>Toggle...</a>",
        action,
        access.ProviderId
    );

    return html;
}
</script>

Solution

  • ClientTemplate isn't using when Kendo Grid is binded to a dataSource on server side like your code.

    You should use Template method of columns like below

     columns.Template(p => "<a href='..../Toggle/Access/" + p.ProviderId + "'>Click</a>");