finereport的js打印,js调用打印_…

转自:http://help.finereport.com/doc-view-1087.html


目录:

1. 问题描述编辑

 

FR工具栏中虽然有打印按钮,但是位置与样式比较死,只能固定在报表上方或下方的工具栏中,不灵活。
用户系统已经自己定义了一套工具栏按钮,页面中只需要嵌入报表内容,不使用FR的工具栏,如果需要打印报表,点击自定义的按钮,调用FR的打印方法进行打印,如下图:
222

2. 解决方案编辑

对于这种打印iframe中嵌入的报表情况,点击“打印”按钮时,先通过js获取到报表所在iframe,进而获得iframe中的window对象,最后调用打印事件,打印出当前iframe中的报表内容。
该方法不管iframe中的报表与当前系统是否是同一个应用,都可以使用,而且不用额外引入finereport.js,避免了js跨域问题。

3. 实现步骤编辑

如报表嵌入在id为reportFrame的iframe中,则点击“打印”按钮触发的事件js如下:
  1.   
  2. "text/javascript">   
  3.     function doFRPrint(){  //点击打印按钮时触发  
  4.         document.getElementByIdx_x('reportFrame').contentWindow.contentPane.pdfPrint();  
  5.         //flash打印:.contentWindow.contentPane.flashPrint();  
  6.         //applet打印:.contentWindow.contentPane.appletPrint();  
  7.         //服务器端打印:.contentWindow.contentPane.printReportServer();  
  8.     }  
  9.     
  10.   

4. 注意编辑

在自定义按钮打印时,有的可能由于业务需要,会将报表所在的iframe隐藏,直接点击打印按钮的时候就打印报表,如果用flash和applet打印的时候,就会发现无法进行下去,这个是因为flash和applet打印的时候会弹出一个打印设置窗口,这个窗口时弹出在报表页面的,即iframe框架内,而iframe框却被隐藏了,所以才无法进行下去,需要在管理平台设置不弹出该设置窗口即可。如下图:
222
发布了54 篇原创文章 · 获赞 6 · 访问量 3万+

猜你喜欢

转载自blog.csdn.net/shen251515338/article/details/79292277