前端通过html2canvas打印echarts图表

项目中遇到echarts图表无法通过window.print正常打印的问题,采用html2canvas将页面转为canvas,然后打印canvas内容。但在实际操作中发现会打印多余的内容。通过CSS的@media和JS动态修改样式,解决了打印时不必要的内容被打印的难题。
摘要由CSDN通过智能技术生成

项目上需要实现导出和打印html,本来直接调用的window.print,结果发现echarts图表无法打印,会是空白的,网上搜索了一下,都是采用转换为64位编码,感觉比较麻烦,找到了另一种办法,利用html2canvas直接将页面转换为canvas,再打印canvas就行了。

代码

// 打印日报
            $("#printall").on("click", function () {
                if (confirm("您确认打印该PDF文件吗?")) {
                    // 先用html2canvas将页面整个转为一张截图,再打印,防止出现echarts无法打印
                    html2canvas(document.getElementById('monthlyReport')).then(
                        function (canvas) {
                            window.print(canvas);  // 打印canvas
                        }
                    );
                }
            });

有个问题,尽管通过document.getElementById('monthlyReport')获取了对应的id,但是在打印时还是会打印当前页面的东西,有一部分不需要的东西也被打印了

如图:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值