Asp.net 在按钮单击时生成文件以供下载-而不破坏其他按钮
我试图提供一个下载报告的选项(csv格式),允许用户选择特定的日期范围。(我还可以选择在页面的GridView中显示相同的信息)。通过使用Response.Clear()、设置ContentType和内容配置、使用Response.Write()、然后使用Response.End()、like和其他许多方法,我可以很好地做到这一点 但是,执行此操作后,按钮似乎不再发回服务器。我可以在GridView中更新我的报告,但只要我导出,两个按钮都不会响应(即,不会生成进一步的服务器端事件)。我怎样才能得到一个文件并保持按钮的响应?这是在SharePoint应用程序页面上,因此母版页中有大量内容。asp代码:Asp.net 在按钮单击时生成文件以供下载-而不破坏其他按钮,asp.net,sharepoint,webforms,Asp.net,Sharepoint,Webforms,我试图提供一个下载报告的选项(csv格式),允许用户选择特定的日期范围。(我还可以选择在页面的GridView中显示相同的信息)。通过使用Response.Clear()、设置ContentType和内容配置、使用Response.Write()、然后使用Response.End()、like和其他许多方法,我可以很好地做到这一点 但是,执行此操作后,按钮似乎不再发回服务器。我可以在GridView中更新我的报告,但只要我导出,两个按钮都不会响应(即,不会生成进一步的服务器端事件)。我怎样才能得
<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();
}
我找到了答案
SharePoint注册一个名为“\u spFormOnSubmitCalled”的变量,该变量将在设置为true后阻止任何回发。我在按钮上添加了一个OnClientClick,在短时间延迟后将其设置回false,就像Stefan的回答一样。我也遇到了类似的问题。
有一个表格和一个按钮,用来将表格导出到excel表格
在标记中使用这段javascript为我修复了它:
<script type='text/javascript'>
_spOriginalFormAction = document.forms[0].action;
_spSuppressFormOnSubmitWrapper = true;
</script>
_spOriginalFormAction=document.forms[0]。操作;
_spSuppressFormOnSubmitWrapper=true;
您正在执行响应。刷新??我最初没有缓冲区/flush,现在有了,没有区别。将类似的代码放入普通ASP.Net文件很好,所以可能是SharePoint正在执行的操作。