码迷,mamicode.com
首页 > Web开发 > 详细

使用jqPrint.js调用浏览器打印界面,打印网页中的某一部分该部分含有ECharts图表

时间:2019-11-24 17:15:11      阅读:318      评论:0      收藏:0      [点我收藏+]

标签:rt4   none   alt   防止   play   echarts   打印预览   图片显示   form   

1、准备好js文件(我用的是谷歌浏览器)

这个文件是为了防止你的jQuery版本过高而不适配的问题

技术图片

 

这是调用浏览器打印的js插件

技术图片

 

 2、引入js文件

1 <script src="js/jquery.jqprint-0.3.js"></script>
2 <script src="js/jquery-migrate-1.2.1.min.js"></script>

3、给你的网页添加一个按钮来出发打印事件

1 <input type="button" onclick="printClassReport()" value="打印班级报告"/>

4、为了保持打印预览的时候你的网页样式不会发生变化,应该打印一个全局的div,然后再讲不想打印的部分隐藏起来,打印完了再把它们显示出来

技术图片

 

技术图片

 

 5、打印的时候将echarts转成图片,让图片显示echarts隐藏,不然的话echarts打印的时候是空白。(没有echarts图表的用户请自动忽略)

技术图片

 

 6、编写js的处理逻辑

 1     <script src="js/jquery.jqprint-0.3.js"></script>
 2     <script src="js/jquery-migrate-1.2.1.min.js"></script>
 3     <script type="text/javascript">
 4         function printClassReport(){
 5             // 获取echarts图表
 6             var myChart1 = echarts.init(document.getElementById(report_classanalyze)); 
 7             var myChart2 = echarts.init(document.getElementById(report_overall));
 8             var myChart3 = echarts.init(document.getElementById(report_studentPassRank));
 9             var myChart4 = echarts.init(document.getElementById(report_problemSubmitRank));
10             //myChart2.setOption(option3);
11             // 获取图片(此时还未实现转换暂时处于隐藏状态)
12             var img1 = document.getElementById(img_report_classanalyze);
13             var img2 = document.getElementById(img_report_overall);
14             var img3 = document.getElementById(img_report_studentPassRank);
15             var img4 = document.getElementById(img_report_problemSubmitRank);
16             // 将图表转换成图片,并保存在图片域当中
17             img1.src = myChart1.getDataURL({
18                 pixelRatio: 2,
19                 backgroundColor: #fff
20             });
21             img2.src = myChart2.getDataURL({
22                 pixelRatio: 2,
23                 backgroundColor: #fff
24             });
25             img3.src = myChart3.getDataURL({
26                 pixelRatio: 2,
27                 backgroundColor: #fff
28             });
29             img4.src = myChart4.getDataURL({
30                 pixelRatio: 2,
31                 backgroundColor: #fff
32             });
33             // 先把图表隐藏,让图片先显示出来
34             document.getElementById(img_report_classanalyze).style.display="block";
35             document.getElementById(img_report_overall).style.display="block";
36             document.getElementById(img_report_studentPassRank).style.display="block";
37             document.getElementById(img_report_problemSubmitRank).style.display="block";
38             document.getElementById(report_classanalyze).style.display="none";
39             document.getElementById(report_overall).style.display="none";
40             document.getElementById(report_studentPassRank).style.display="none";
41             document.getElementById(report_problemSubmitRank).style.display="none";
42             // 隐藏不想显示的区域
43             $(".content_l").hide();
44             $(".search").hide();
45             $("form").hide();
46             // 打印选定的web页面
47             $("#print").jqprint();
48             // 将之前隐藏的页面重新显示出来
49             $("form").show();
50             $(".search").show();
51             $(".content_l").show();
52             // 再将图片隐藏,将动态echarts突变显示出来
53             document.getElementById(img_report_classanalyze).style.display="none";
54             document.getElementById(img_report_overall).style.display="none";
55             document.getElementById(img_report_studentPassRank).style.display="none";
56             document.getElementById(img_report_problemSubmitRank).style.display="none";
57             document.getElementById(report_classanalyze).style.display="block";
58             document.getElementById(report_overall).style.display="block";
59             document.getElementById(report_studentPassRank).style.display="block";
60             document.getElementById(report_problemSubmitRank).style.display="block";
61         }
62     </script>

我有四张echarts图表所以js代码比较繁琐,如果你的echarts表只有一张,把代码中多余的东西删除即可。

 

展示区:

技术图片

 

 技术图片

 

 打印的时候只显示了红色框里的内容。

最后祝成功!!!

 

使用jqPrint.js调用浏览器打印界面,打印网页中的某一部分该部分含有ECharts图表

标签:rt4   none   alt   防止   play   echarts   打印预览   图片显示   form   

原文地址:https://www.cnblogs.com/blogs-jch/p/11922797.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!