2016-12-01 138 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);