0

我正在尝试提供一个选项来下载报告(以 csv 格式),允许用户选择特定的日期范围。(我还可以选择在页面上的 GridView 中显示相同的信息)。我可以通过使用 Response.Clear()、设置 ContentType 和 content-disposition、使用 Response.Write() 和 Response.End() 来很好地做到这一点,就像这个博客和许多其他人一样。

但是,执行此操作后,按钮似乎不再回发到服务器。我可以多次在 GridView 中更新我的报告,但是只要我导出两个按钮都不会响应(即不会生成更多的服务器端事件)。如何获取文件并保持按钮响应?这是在 SharePoint 应用程序页面上,因此母版页中有很多内容。

4

3 回答 3

1

我有一个类似的问题。有一个带有网格的表单和一个应该将网格导出到 Excel 工作表的按钮。

在标记中使用这段 javascript 为我修复了它:

<script type='text/javascript'>
  _spOriginalFormAction = document.forms[0].action;
  _spSuppressFormOnSubmitWrapper = true;
</script> 
于 2013-05-03T15:38:54.183 回答
0

ASP代码:

   <form id="form1" runat="server">    
   <asp:GridView ID="GridView1" runat="server" AutoGenerateColumns = "false" Font-Names = "Arial" Font-Size = "11pt" AlternatingRowStyle-BackColor = "#C2D69B" HeaderStyle BackColor = "green" AllowPaging ="true" OnPageIndexChanging = "OnPaging" >
    <Columns>
    <asp:BoundField ItemStyle-Width = "150px" DataField = "CustomerID" HeaderText ="CustomerID" />
    <asp:BoundField ItemStyle-Width = "150px" DataField = "City" HeaderText = "City"/
    <asp:BoundField ItemStyle-Width = "150px" DataField = "Country" HeaderText = "Country"/>
    <asp:BoundField ItemStyle-Width = "150px" DataField = "PostalCode" HeaderText = "PostalCode"/>
    </Columns>
  </asp:GridView>
  <br />
   <asp:Button ID="Button1" runat="server" Text="ExportToCSV" OnClick="btnExportCSV_Click" />
   </form>

Protected void btnExportCSV_Click(object sender, EventArgs e)
{
    Response.Clear();
    Response.Buffer = true;
    Response.AddHeader("content-disposition","attachment;filename=GridViewExport.csv");
    Response.Charset = "";
    Response.ContentType = "application/text";

    GridView1.AllowPaging = false;
    GridView1.DataBind();

    StringBuilder sb = new StringBuilder();
    for (int k = 0; k < GridView1.Columns.Count; k++)
    {
        //add separator
        sb.Append(GridView1.Columns[k].HeaderText + ',');
    }
    //append new line
    sb.Append("\r\n");
    for (int i = 0; i < GridView1.Rows.Count; i++)
    {
        for (int k = 0; k < GridView1.Columns.Count; k++)
        {
            //add separator
            sb.Append(GridView1.Rows[i].Cells[k].Text + ',');
        }
        //append new line
        sb.Append("\r\n");
    }
    Response.Output.Write(sb.ToString());
    Response.Flush();
    Response.End();
}
于 2013-04-30T15:44:41.550 回答
0

在这个问题中找到了答案

SharePoint 注册了一个名为“_spFormOnSubmitCalled”的变量,一旦设置为 true,它将阻止任何回发。我已经在我的按钮上添加了一个 OnClientClick ,以便在短暂延迟后将其设置回 false ,如 Stefan 的回答所示。

于 2013-04-30T19:11:59.907 回答