1

我正在使用免费的 Telerik.Web.Mvc 网格并遵循以下示例:http ://demos.telerik.com/aspnet-mvc/grid/hierarchyajax

我的问题:

在用户输入一些数据并使用搜索按钮提交后,我在网格中填充搜索结果控制器操作不会为我执行。

如果我加载网格第一次页面加载它执行。但不是当在搜索按钮中加载网格时单击

我项目中的代码:

我的 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));
    }

我错过了什么?我的版本比demo还要简单。有任何想法吗?

谢谢。

我找到了另一个可以做我想做的事情的网格。它被称为 jqGrid

4

0 回答 0