2013-04-30 193 views
0

我試圖提供一個選項來下載報告(採用csv格式),允許用戶選擇特定的日期範圍。 (我也可以選擇在頁面上的GridView中顯示相同的信息)。我可以通過使用Response.Clear(),使用Response.Write()和Response.End()(如this blog等)設置ContentType和content-disposition來做到這一點。生成文件供下載按鈕點擊 - 不破壞其他按鈕

但是,這樣做後,按鈕不再似乎回發到服務器。我可以在GridView中更新我的報告,但是我喜歡很多次,但是一旦我導出,兩個按鈕都不會響應(即不再生成服務器端事件)。我怎樣才能得到一個文件,並保持按鈕重新編碼?這是在SharePoint應用程序頁面上的,因此Master頁面中會出現一些內容。

+0

投擲類似的代碼轉換爲純ASP.Net文件能正常工作,所以它可能是東西的SharePoint在做什麼。 – lgaud 2013-04-30 17:05:33

回答

0

而且我找到了答案in this question

的SharePoint註冊了一個名爲 「_spFormOnSubmitCalled」,這將防止任何回傳,一旦它被設置爲true變量。我已經添加了一個OnClientClick到我的按鈕,在短暫的延遲後將它設置爲false,就像在Stefan的回答中一樣。

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(); 
} 
+0

這幾乎是我已經做的。 – lgaud 2013-04-30 15:45:40

+0

你在做response.flush? – 2013-04-30 15:47:29

+0

我原本沒有緩衝區/沖洗,我現在沒有區別。 – lgaud 2013-04-30 15:50:50

1

我有類似的問題。 有一個網格和一個按鈕,應該將網格導出到Excel工作表。

利用這段JavaScript代碼的標記內固定對我來說:

<script type='text/javascript'> 
    _spOriginalFormAction = document.forms[0].action; 
    _spSuppressFormOnSubmitWrapper = true; 
</script>