2016-12-01 96 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")); 
    }) 
}); 

并选择搜索paramters另一个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调用。更新到剑道和jQuery,所以我觉得我只是格式化行:

grid.datasource.data = "FillSearchParams"; 
在按钮呼叫

在此先感谢。

+0

在控制器上为jquery调用定义了什么形式参数?当您返回searchParms时,您正在为数据添加额外的json包装器。 –

+0

public ActionResult GetSpecimenDetail([DataSourceRequest] DataSourceRequest x,SpecimenDetail请求) x一直是这里的问题,无论出于何种原因,如果调用来自它的工作网格,而不是按钮。 – TrevorGoodchild

+0

我认为数据函数应该返回一个SpecimenDetail {}来匹配预期的结果。 –

回答

0

需与在jQuery的呼叫添加此行:

grid.dataSource.page(1);