Asp.net 在Safari中导出到Excel

Asp.net 在Safari中导出到Excel,asp.net,.net-3.5,safari,cross-browser,export-to-excel,Asp.net,.net 3.5,Safari,Cross Browser,Export To Excel,我正在开发一个最近从.NET1.1转换到3.5的web产品。有几页我们正在努力使Mac/Safari兼容。我修复了由JavaScript引起的其他几个问题。但是,导出到Excel和Word仍然没有响应 我们有一个包含脚本C#的.aspx页面来进行导出,因为这个功能在网站上被广泛使用 它在IE中输出得很好,但在Safari甚至Firefox中都没有响应 我正在使用.NETFramework3.5和VisualStudio2008。导出数据的代码如下所示: private void PageExce

我正在开发一个最近从.NET1.1转换到3.5的web产品。有几页我们正在努力使Mac/Safari兼容。我修复了由JavaScript引起的其他几个问题。但是,导出到Excel和Word仍然没有响应

我们有一个包含脚本C#的.aspx页面来进行导出,因为这个功能在网站上被广泛使用

它在IE中输出得很好,但在Safari甚至Firefox中都没有响应

我正在使用.NETFramework3.5和VisualStudio2008。导出数据的代码如下所示:

private void PageExcelClick_Click(object sender, System.Web.UI.WebControls.CommandEventArgs e)
        {
            HideListBox_LB();
            Response.ContentType = "application/vnd.ms-excel";
            Response.Charset = "";
            this.EnableViewState = false;
            System.IO.StringWriter tw = new System.IO.StringWriter();
            System.Web.UI.HtmlTextWriter hw = new HtmlTextWriter(tw);
            divPageResultPanel.RenderControl(hw);
            Response.Write(tw.ToString());
            Response.End();     
            ShowListBox_LB();
        }



private void HideListBox_LB()
{
         foreach(Control cnt in Page.Controls)
    {
        if(cnt.Controls.Count > 0)
        {
            Control ctlLB = cnt.FindControl("divExcelExportHide");
            if(ctlLB != null)
                ctlLB.Visible = false;
        }
    }
}

private void ShowListBox_LB()
{
     foreach(Control cnt in Page.Controls)
    {
       if(cnt.Controls.Count > 0)
        {
            Control ctlLB = cnt.FindControl("divExcelExportHide");
            if(ctlLB != null)
                ctlLB.Visible = true;
        }
    }
}
更新: 我已尝试完全删除页面中包含的方面。我把导出登录直接放在codebeing中,甚至把菜单拉到页面上

更新#2:
已将代码转换为用户控件,现在导出工作

调试运行Safari时,它甚至不会为Excel按钮注册单击事件,而断点是从IE中命中的。调试运行Safari时,它甚至不会为Excel按钮注册单击事件,而断点是从IE中命中的。