1

私は無料の Telerik.Web.Mvc グリッドを使用しており、次の例に従っています: http://demos.telerik.com/aspnet-mvc/grid/hierarchyajax

私の問題:

ユーザーがデータを入力し、検索ボタンを使用して送信した後、グリッドに検索結果を入力しています DetailView() メソッドでは、「SearchQuote_QuotesForHierarchyAjax」メソッドを参照します。コントローラーのアクションが実行されません。

グリッドを初めてロードすると、ページがロードされて実行されます。ただし、検索ボタンのクリックでグリッドがロードされたときはそうではありません

私のプロジェクトのコード:

私の SearchQuote.aspx ビューは次のようになります

  <%= Html.Telerik().Grid(Model.QuoteSummaryList)
                .Name("SearchQuoteGrid")
    .Columns(columns =>
    {
        columns.Bound(q => q.QuoteId).Title("Quote #").Width(50);
        columns.Bound(q => q.AxiomId).Title("Axiom Id").Width(180);

    })
     .ClientEvents(events => events.OnRowDataBound("quotes_onRowDataBound"))
    .DetailView(details => details.ClientTemplate(
     Html.Telerik().Grid(Model.QuoteSubSummaryList)
        .Name("Quotes_<#= QuoteId #>")
        .Columns(columns =>
        {
            columns.Bound(o => o.PositionCode).Width(101);
            columns.Bound(o => o.Group).Width(140);
        })
        .DataBinding(dataBinding => dataBinding.Ajax()
        .Select("SearchQuote_QuotesForHierarchyAjax", "SearchQuote", new
        {quoteid ="<#= QuoteId #>"}))
        .Pageable()
        .Sortable()
        .Filterable()
        .ToHtmlString()
    ))
    .DataBinding(dataBinding => dataBinding.Ajax()
                                .Select("SearchQuote_Select", "SearchQuote"))
    .Sortable()
    .Pageable(p => p.PageSize(3))
%>
<script type="text/javascript">

function expandFirstRow(grid, row) {
      if (grid.$rows().index(row) == 0) {
          grid.expandRow(row);
      }
   }

   function quotes_onRowDataBound(e) {
        var grid = $(this).data('tGrid');
        expandFirstRow(grid, e.row);
    }
</script>

そして SearchQuoteController にはこのコードがあります。

    [AcceptVerbs(HttpVerbs.Post)]
    [GridAction]
    public ActionResult SearchQuote_QuotesForHierarchyAjax(int quoteid)
    {
       List<QuoteLineSummaryDM> sublist = new List<QuoteLineSummaryDM>();

       QuoteLineSummaryDM a = new QuoteLineSummaryDM();
         a.PositionCode =  "50";
         a.Group = "1";
         sublist.Add(a);

       QuoteLineSummaryDM b = new QuoteLineSummaryDM();
         b.PositionCode =  "40";
         b.Group = "2";
         sublist.Add(b);

         var qrows = (from r in sublist
                      select r).AsQueryable();

         return View(new GridModel(qrows));
    }

私は何が欠けていますか?私のバージョンは、デモよりもさらにシンプルです。何か案は?

ありがとう。

私がやりたいことをする別のグリッドを見つけました。それはjqGridと呼ばれます

4

0 に答える 0