Kendo UI:数据源刷新数据后Excel导出无法正常工作

时间:2015-02-06 23:56:45

标签: kendo-ui kendo-grid kendo-asp.net-mvc

我有一个网格,当用户点击一个按钮时,它会获得一些参数并刷新数据源:

var grdUP = $("#weblogGrid").data("kendoGrid");
grdUP.dataSource.transport.options.read.url = url; // new url

//Read data source to update
grdUP.dataSource.read();

它工作正常。新数据显示在网格中。并且网格有另一个按钮,它将数据导出到excel。我使用下面的代码(也尝试了内置按钮):

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

它实际上将数据导出到excel文件。

但是,它始终导出网格中的初始数据,而不是数据用户刷新。

例如,当网格首次出现时,它有10行数据。刷新后,它有5行数据。现在,如果导出,它仍会导出10行数据,尽管网格中的数据不同。

这是一个Bug吗?或者,也许我在刷新网格中做错了什么?

由于

=============================== 编辑以澄清某些内容

感谢。目前,我使用以下方式获取新数据:

var url = '/WeblogReport/GetWebLogList?fromDate=' + fromDate + '&toDate=' + toDate;
var grdUP = $("#myGrid").data("kendoGrid");
//Set url property of the grid data source
grdUP.dataSource.transport.options.read.url = url;
//Read data source to update
grdUP.dataSource.read();

所以我改为:

// get value of date
....

$.ajax({
    type: "GET",
    dataType: "json",
    url: "/WeblogReport/GetWebLogList",
    data: { FromDate: fromDate, ToDate: toDate },
    success: function (data) {
        alert(data);

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

        grid.dataSource.data(data);
        grid.refresh();
    }
});

不知何故,它没有显示新数据。有什么建议?

非常感谢。


添加更多说明

这是Json的电话。

success: function (data) {
    var newdata = [{ "UserName": "username", "ClientIP": "1.1.1.1"}];

    $("#myGrid").data("kendoGrid").dataSource.data(newdata);
    $("#myGrid").data("kendoGrid").refresh();

    //$("#myGrid").data("kendoGrid").saveAsExcel();
}

4 个答案:

答案 0 :(得分:0)

检查一下:

http://jsfiddle.net/Sowjanya51/o8cw3vj8/

$('#grid1').data('kendoGrid').dataSource.data(newdata);  
$('#grid1').data('kendoGrid').refresh();    

您需要更新dataSource并重新加载网格,否则即使UI显示新数据,网格dataSource仍将引用旧数据。

答案 1 :(得分:0)

只需将网格上的“allPages”选项设置为“True”即可。像这样:

excel: {
    fileName: "Export.xlsx",
    filterable: true,
    allPages: true
},

答案 2 :(得分:0)

如果在从数据源读取后刷新网格,原始解决方案应该没问题。

  1 error(s) on assignment of multiparameter attributes [error on assignment [3, 3] to backup (Missing Parameter - backup(1))]

我遇到了同样的问题,这解决了我。您和我的方法之间的唯一区别是您正在更改数据源的读取URL,而我正在更改读取方法的数据参数。不应该有任何区别,但为了以防万一,我会提到它。

答案 3 :(得分:0)

设置以下两个字段以使Excel导出正常工作:

grid.dataSource.transport.options.read.url = url;
grid.options.dataSource.transport.read.url = url;