2

Telerikグリッドを使用して、ユーザーが受け取ったメモを以下に示します。コードは次のとおりです。

<%Html.Telerik().Grid<UserManagement.Models.SentMemos>() 
    .Name("ReceivedMemos") 
    .Sortable(sorting => sorting 
        .OrderBy(sortOrder => sortOrder.Add(o => o.MemoDate).Descending()))         
    .DataBinding(dataBinding => dataBinding 
        //Ajax binding 
    .Ajax() 
    //The action method which will return JSON 
    .Select("_AjaxBindingReceivedMemos", "OA" ) 

        ). 
        Columns(colums => 
        { 
            colums.Bound(o => o.MemoID).ClientTemplate(Html.ActionLink("Reply", "ReplyMemo", "OA", new { MemoID = "<#=MemoID#>"}, null).ToString()).Title("Reply").Filterable(false).Sortable(false); 
            colums.Bound(o => o.MemoID).ClientTemplate(Html.ActionLink("Acknowledge", "PreviewMemo", "OA", new { id = "<#=MemoID#>"}, null).ToString()).Title("Acknowledge").Filterable(false).Sortable(false); 
            colums.Bound(o => o.Subject).ClientTemplate(Html.ActionLink("<%#=Subject#>", "PreviewMemo", "OA", new { id = "<#=MemoID#>" }, null).ToString()).Title("Subject"); 
            //colums.Bound(o => Html.ActionLink(o.Subject,"PreviewMemo","OA",new{id=o.MemoID},null).ToString()).Title("Subject"); 
            colums.Bound(o => o.FromEmployeeName); 
            colums.Bound(o => o.MemoDate); 
            }) 
    .Sortable() 
    .Filterable() 
     .RowAction((row) => 
     {              
             row.HtmlAttributes.Add("style", "background:#321211;"); 
     }) 
    .Pageable(pager=>pager.PageSize(6)) 
    .PrefixUrlParameters(false)   

       //.ClientEvents(events => events.OnRowDataBound("onRowDataBound")) 
        .Render();          
  %> 

ここで、3番目の列(件名)をバインドしています。私の意図は、件名が表示テキストであり、からの動的IDが必要なActionLinkを作成することです<#=MemoID#>。メモIDは正常に機能しており、動的なメモIDとのリンクが表示されます。問題は件名にあります。つまり"<#=Subject#>"、メモの実際の件名にマッピングせずに、()が画面上にそのままレンダリングされます。私も("<%#=Subject%>")を試しましたが、効果はありません。どんな助けでも大歓迎です

よろしく

4

2 に答える 2

13

今少し遅れているかもしれませんが、おそらくこれは他の人を助けるでしょう:

次のように、テンプレートを介してこれを行います。

columns.Bound(c => c.ID).ClientTemplate(

           Html.ActionLink("<#= SomeTextValue #>", "SomeAction", "SomeController", new { ID = "<#= ID #>" }, null).ToString()

      ).Title("");
于 2010-11-22T15:39:37.573 に答える
1

これはかなり遅いことに気づきましたが、私は最終的に理解した非常によく似た問題を抱えていて、このリンクが検索結果中に表示されました。Ajax.ActionlinkをMVCグリッドのクライアントテンプレートに
追加しようとしました。最後に、UpdateTargetID="myElement"に起因する問題が見つかりました。 Ajax.ActionLinkは、更新ターゲットに対してエスケープされていない「#」を生成します。 私の回避策は次のとおりです。

columns.Bound(p => p.ID).Title("myTitle")
                            .ClientTemplate(Ajax.ActionLink("View", "myAction", "myController", new { myParam = "#=ID#" }, new AjaxOptions() { OnSuccess = "myJSFunction" }).ToHtmlString());


それで:

function myJSFunction(response) {
    $("#updateTargetElement").html(response);
}
于 2015-06-25T19:25:44.590 に答える