生成文件供下载按钮点击 - 不破坏其他按钮
问题描述:
我试图提供一个选项来下载报告(采用csv格式),允许用户选择特定的日期范围。 (我也可以选择在页面上的GridView中显示相同的信息)。我可以通过使用Response.Clear(),使用Response.Write()和Response.End()(如this blog等)设置ContentType和content-disposition来做到这一点。生成文件供下载按钮点击 - 不破坏其他按钮
但是,这样做后,按钮不再似乎回发到服务器。我可以在GridView中更新我的报告,但是我喜欢很多次,但是一旦我导出,两个按钮都不会响应(即不再生成服务器端事件)。我怎样才能得到一个文件,并保持按钮重新编码?这是在SharePoint应用程序页面上的,因此Master页面中会出现一些内容。
答
而且我找到了答案in this question
的SharePoint注册了一个名为 “_spFormOnSubmitCalled”,这将防止任何回传,一旦它被设置为true变量。我已经添加了一个OnClientClick到我的按钮,在短暂的延迟后将它设置为false,就像在Stefan的回答中一样。
答
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();
}
答
我有类似的问题。 有一个网格和一个按钮,应该将网格导出到Excel工作表。
利用这段JavaScript代码的标记内固定对我来说:
<script type='text/javascript'>
_spOriginalFormAction = document.forms[0].action;
_spSuppressFormOnSubmitWrapper = true;
</script>
投掷类似的代码转换为纯ASP.Net文件能正常工作,所以它可能是东西的SharePoint在做什么。 – lgaud 2013-04-30 17:05:33