ReportViewer在Chrome 浏览器中无法显示的解决方法

本文介绍了解决ASP.NET ReportViewer组件在Chrome浏览器下无法正确显示报表的问题,通过重写Render事件避免了JavaScript死循环,同时提供了替代方案以在Chrome下正常显示报表并具备基本功能。

Vs2010中使用ReportViewer显示报表。在IE下显示正常,但到Chrome下无法显示报表,但报表工具条可以显示。说明数据有取出,但无法显示。在网上找到了解决方法。

    主要原因是ReportViewer中的Js在Chrome下会造成死循环。

    解决方法是重写ReportViewer的Render事件。具体代码如下。

复制代码
     public   class  MyReportViewer : Microsoft.Reporting.WebForms.ReportViewer
    {
        
protected   override   void  Render(HtmlTextWriter writer)
        {
            
using  (StringWriter sw  =   new  StringWriter())
            {
                HtmlTextWriter tmpWriter 
=   new  HtmlTextWriter(sw);
                
base .Render(tmpWriter);
                
string  val  =  sw.ToString();
                val 
=  val.Replace( @" != 'javascript:\'\'' " @" != 'javascript:\'\'' && false " );
                writer.Write(val);
            }
        }
    }
复制代码

 

 

然后我们使用重写过的MyReportViewer加载报表数据。 Html代码如下:

 

         < cc1:MyReportViewer  ID ="rvSignUp"  runat ="server"  EnableTheming ="false"  Width ="100%"
            Height
="100%"  ShowWaitControlCancelLink ="false"  ShowPromptAreaButton ="false"
            ShowCredentialPrompts
="false"  ShowExportControls ="false"  SizeToReportContent ="true" >
        
</ cc1:MyReportViewer >

 

 

参考的网上原文为:http://stackoverflow.com/questions/1784642/asp-net-reportviewer-google-chrome-cpu-usage 

============================================================================================

方法2:
<table id="reportviewertable" align="center">
    <tr>
        <td>
            <asp:Label ID="lblErrorMessage" runat="server" Font-Bold="True" ForeColor="Red" Visible="False" />
        </td>
    </tr>
    <tr>
        <td width="760px">
            <rsweb:ReportViewer ID="rvRepViewer" runat="server" width="100%" height="100%"
                ZoomMode="PageWidth" ShowBackButton="true" SizeToReportContent="True" />
        </td>
    </tr>
</table>

这样可以出现导出按钮。再来打印。
评论 2
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值