利用jqprint如何实现打印页面内容

qprint是一个基于jquery编写的页面打印的一个小插件,但是不得不承认这个插件确实很厉害,下面这篇文章主要给大家介绍了关于利用jqprint插件如何打印页面内容的实现方法,需要的朋友可以参考借鉴,下面随着我来一起学习学习吧。

业务场景

客户需要在页面有一个打印按钮,点击之后可以打印Echarts图表的内容以及文字提示信息,经谷歌搜索发现,实现方法大概有三种之多,其他两种不太熟悉,而采用的这种打印方式是一个在jQuery的基本上开发的一个print插件,因此可以使用jQuery的方式查找元素,因此决定采用这种方式。

先看一下实现的效果图,如下:

利用jqprint如何实现打印页面内容

实现效果图

引入js文件


登录后复制

注意:这里是先引入的jQuery文件,如果没有引入第一个js文件的话,会出现兼容性问题,导致使用jqprint打印时报错。

html页面

这里面的html标签很多的

 

登录后复制  

       

用户信息

     

         

姓名:

    18030632605          

性别:

    男          

年龄:

    41          

身份证:

    52272419770101059X          

所属机构:

    上海市政法委        …… 

当然下面还有很多的html标签,在这里就不展示了。

打印按钮点击之后执行的函数

function btnPrintClick(){ var imgBox = $('#img_box'); var chartBox = $('#main'); if (imgBox.length ');  imgBox = $('#img_box'); } // 将echart生成图片并放入img-box,并显示图片img-box imgBox.html('').css('display','block'); // 隐藏echart图chart-box chartBox.css('display','none'); // 调整img大小 var img = imgBox.find('img'); var imgWidth = img.width(); var showWidth = 1000; // 显示宽度,即图片缩小到的宽度 if (imgWidth > showWidth) { // 只有当图片大了才缩小  var imgNewHeight = img.height() / (imgWidth / showWidth);  img.css({'width': showWidth + 'px', 'height': imgNewHeight + 'px'}); } var imgBox2 = $('#img_box2'); var chartBox2 = $('#main2'); if (imgBox2.length ');  imgBox2 = $('#img_box2'); } // 将echart生成图片并放入img-box,并显示图片img-box imgBox2.html('').css('display','block'); // 隐藏echart图chart-box  chartBox2.css('display','none'); // 调整img大小 var img2 = imgBox2.find('img'); var img2Width = img2.width(); var show2Width = 1000; // 显示宽度,即图片缩小到的宽度 if (img2Width > show2Width) { // 只有当图片大了才缩小  var img2NewHeight = img2.height() / (img2Width / show2Width);  img2.css({'width': show2Width + 'px', 'height': img2NewHeight + 'px'}); } // 打印 $("#TestQuestions").jqprint(); // 执行打印后再切换回来 // 显示echart图chart-box chartBox.css('display','block'); chartBox2.css('display','block'); // 隐藏图片img-box imgBox.css('display','none'); imgBox2.css('display','none');}

登录后复制

注意事项:

这里使用了图片的缩放比例的方式。比如Echarts图表要显示的内容特别多的话,一般在html页面中采用的是在X轴上使用滚动条的方式,但是打印时可以将Echarts图表先转换成图片,并等比例进行缩放,打印完毕之后再还原回来即可。

任何不需要打印的标签都可以先隐藏。对于不需要出现在打印页面的标签内容,我们在打印之前使用jQuery查找到对应的元素,将该元素隐藏起来,打印结束之后,再将隐藏的元素显示出来即可。

属性

debug: false, //如果是true则可以显示iframe查看效果(iframe默认高和宽都很小,可以再源码中调大),默认是false

importCSS: true, //true表示引进原来的页面的css,默认是true。(如果是true,先会找$(“link[media=print]”),若没有会去找$(“link”)中的css文件)

printContainer: true, //表示如果原来选择的对象必须被纳入打印(注意:设置为false可能会打破你的CSS规则)。

operaSupport: false //表示如果插件也必须支持歌opera浏览器,在这种情况下,它提供了建立一个临时的打印选项卡。默认是true

上面是我整理给大家的,希望今后会对大家有帮助。

相关文章:

requireJS如何实现模块加载器?

requireJS如何实现模块加载器?

requireJS如何实现模块加载器?

requireJS如何实现模块加载器?

以上就是利用jqprint如何实现打印页面内容的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/3185057.html

(0)
上一篇 2025年3月31日 22:12:50
下一篇 2025年3月31日 22:12:56

AD推荐 黄金广告位招租... 更多推荐

发表回复

登录后才能评论