2016-12-01 16 views
0

私たちは検索ページで使用している剣道UIグリッドを持っている:剣道UIデータソースの問題

@(Html.Kendo().Grid<SMT.Models.SpecimenDetail>() 
    .Name("SpecimenDetailGrid") 
    .Columns(columns => 
    { 
     columns.Bound(e => e.uniqueID).Hidden(); 
     columns.Bound(e => e.contact_business_email).Width(120).Title("Owner Email"); 
     columns.Bound(e => e.contact_business_phone).Width(120).Title("Owner Phone"); 
    }) 
    .ToolBar(tools => 
      { 
       tools.Excel(); 
       tools.Custom().Text("Back to Specimen Summary").HtmlAttributes(new { id = "goBack", style = "margin-left: 880px;" }); 
      }) 
    .Excel(excel => excel 
     .AllPages(true) 
     .FileName("SpecimenDetailGridData.xlsx") 
     .Filterable(true) 
     .ProxyURL(Url.Action("Excel_Export_Save", "Home")) 
     ) 
    .Resizable(x => x.Columns(true)) 
    .Reorderable(x => x.Columns(true)) 
    .HtmlAttributes(new { style = "height:500px;" }) 
    .Pageable() 
    .AutoBind(false) 
    .Editable(e => e.Mode(GridEditMode.InLine)) 
    .DataSource(datasource => datasource 
     .Ajax() 
       .Model(model => { 
        model.Id(p => p.uniqueID); 
        model.Field(p => p.SampleID).Editable(false); 
        model.Field(p => p.company_business_name).Editable(false); 

        // disable company name on edit 
        // model.Field(p => p.company_business_name).Editable(false); 
       }) 
     .Read(read => read.Action("GetSpecimenDetail", "Home").Data("FillSearchParms")) 
     .Update(update => update.Action("UpdateSpecimen", "Home").Data("FillUpdateParms")) 
     .Destroy(destroy => destroy.Action("DeleteSpecimen", "Home")) 
     .PageSize(10) 
     .Events(e => { e.RequestEnd("onRequestEnd");}) 
     ) 
) 

そして、その同じページに、我々はグリッドをリフレッシュするjQueryの関数を呼び出すボタンがあり

$(document).ready(function() { 

    $("#SearchBtn").click(function (e) { 
     e.preventDefault(); 

     $("#divSearchSpecimenDetail").attr("style", "display: block;"); 

     var grid = $("#SpecimenDetailGrid").data("kendoGrid"); 

     //think this is the problem 
     grid.datasource.data = "FillSearchParams"; 
     grid.dataSource.read(); 
     grid.refresh(); 

     e.preventDefault(); 
     hideColumns(specimenCat); 

     $("#searchbar").data("kendoPanelBar").collapse($("li.k-state-active")); 
    }) 
}); 

と検索偶然にを選択し、別のjQueryの機能:

function FillSearchParms() { 
    var units = defaultDDObj("Units"); 
    var specimenCat = defaultDD("SpecimenCategory"); 

    //debugger; 

    var searchParms = { 
     SpecimenCategory: specimenCat, 
     Units: units.Value, 

     uniqueID: $("#uniqueID").val(), 
     SampleID: $("#SampleID").val(), 

     ThicknessAtWeld1From: $("#ThicknessAtWeld1From").val(), 
     ThicknessAtWeld1To: $("#ThicknessAtWeld1To").val(), 

     OverlayThicknessFrom: $("#OverlayThicknessFrom").val(), 
     OverlayThicknessTo: $("#OverlayThicknessTo").val(), 

    } 

問題が何らかの理由clickinのために、ありますgボタンはFillSearchParams呼び出しではなく、読み取りアクションを呼び出しています。 Newer to Kendo、jQueryなので、私はちょうどラインをフォーマットしていると思う:

ボタンコール。

ありがとうございます。 jQueryの呼び出しで、この行を追加する必要が

+0

jquery呼び出しのコントローラでは、どのような仮パラメータが定義されていますか? searchParmsを返すと、追加のjsonラッパーがデータに追加されます。 –

+0

public ActionResult GetSpecimenDetail([DataSourceRequest] DataSourceRequest x、SpecimenDetail request) ここでは、何らかの理由でxが問題なく使用されています。 – TrevorGoodchild

+0

私は、データ関数がSpecimenDetail {}を返して、期待されるものと一致するはずだと思います。 –

答えて

関連する問題