利用lodop打印控件轻松实现批量打印
最近在做一个打印程序,要实现批量打印功能,在网上找了很多天,也在tp官网咨询大牛们,对大家的的提议我一一进行了研究,总结如下:
要实现批量打印可以有两个办法:
一是利用专业的报表程序,能实现十分复杂的需求,但学习报表也是很痛苦的一件事,我专心研究了一天都没啥进展,也许我实在太菜了。这种方法推荐锐浪报表,免费还好用。
二是利用js插件实现,也在网上找了很多,最后感谢hunduncn,他建议我使用lodop(详见:http://www.thinkphp.cn/topic/12938.html),由于对html+css十分熟悉,所以上手不难,真的很好用。
Lodop(标音:劳道谱,俗称:露肚皮)是专业WEB控件,用它既可裁剪输出页面内容,又可用程序代码直接实现复杂打印。控件功能强大,却简单易用,所有调用如同JavaScript扩展语句。官网:http://www.lodop.net/,从官网下载的程序中有很多例子,也非常全面。
下面奉上代码:
- <html xmlns="http://www.w3.org/1999/xhtml">
- <head>
- <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
- <title>无标题文档</title>
- <script language="javascript" src="LodopFuncs.js"></script>
- </head>
- <body>
- <form id="form1">
- 11111
- </form>
- <a href="javascript:prn1_preview()">打印预览</a><br/>
- <a href="javascript:prn1_print()">直接打印</a>
- <script language="javascript" type="text/javascript">
- var LODOP; //声明为全局变量
- function prn1_preview() {
- CreateOneFormPage();
- LODOP.PREVIEW();
- };
- function prn1_print() {
- CreateOneFormPage();
- LODOP.PRINT();
- };
- function CreateOneFormPage(){
- LODOP=getLodop();
- LODOP.PRINT_INIT("打印控件功能演示_Lodop功能_表单一");
- LODOP.SET_PRINT_STYLE("FontSize",18);
- LODOP.SET_PRINT_STYLE("Bold",1);
- LODOP.ADD_PRINT_TEXT(50,231,260,39,"");
- LODOP.ADD_PRINT_HTM(88,200,350,600,document.getElementById("form1").innerHTML);
- };
- </script>
- </body>
- </html>
复制代码
应该都能看懂,通过id操作,要是实现打印时候的样式导入,代码如下:
- function CreateOneFormPage(){
- LODOP=getLodop();
- var strStyleCSS="<link href='print.css' type='text/css' rel='stylesheet'>";
- var strFormHtml=strStyleCSS+"<body>"+document.getElementById("form1").innerHTML+"</body>";
- LODOP.PRINT_INIT("打印准考证");
- LODOP.ADD_PRINT_HTM(0,0,"100%","100%",strFormHtml);
- };
复制代码
ps:lodop的A4纸张,打印区域大小为758px*1090px
人生目标:50岁时财务自由,周游世界@