含有echart 图表的报表打印

这一生的挚爱 提交于 2020-03-14 10:41:19

最近需要打印含有echart图表的报表,采用jqprint插件打印,直接用jqprint打印echart的图不显示,这里需要借助img 来实现

首先下载jqprint插件,把jquery和jqprint文件引用

<script src="../../plugins/jQuery/jquery-1.4.4.min.js"></script>
 <script src="../../plugins/jqprint/jquery.jqprint-0.3.js"></script>

在页面上增加一个按钮  <input class="" type="button" onclick=" a()" value="打印"/>

在生成图表的div上面增加img元素

 <div class="">

       <img id="printImg1" style="width:100%;display:none;" >

      <div id="barchart1" style="height:450px;"></div>

      </div>

var myChart2 = echarts.init(document.getElementById('barchart1'),theme); 

     myChart2.setOption(option3);

     var img1 = document.getElementById('printImg1');

   img1.src = myChart2.getDataURL({

    pixelRatio: 2,

    backgroundColor: '#fff'

   });

下面为调用jqprint插件,并把echart生成的图隐藏,显示img里面的图,特别注意width的设定会影响打印字体的大小
<script language="javascript">

  function  a(){

  $("#printArea").css("width","305mm");

  document.getElementById('printImg1').style.display="block";

  document.getElementById('barchart1').style.display="none";

  $("#printArea").jqprint();

  }

  </script>

更多前端实用知识

如有疑问请关注微信公众号:前端之攻略

我会详细解答

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!