jsp实现套打(发票打印)


   jsp普通打印很简单,有很多方式,可以用window.print()这种自带的方法,也可以用组件webBrowser,还可以用ScriptX这样的第三方组件来实现。这样的打印都是打印默认的A4,如果碰到到发票的打印要怎么实现呢?
    首先,我们要明白,实现网页套打,还是用我们现有的方法去实现。
    其次,要知道发票的使用的纸张是不一样的,首先它用的是复写纸,要实现复写纸的打印,必须要用针式打印机,这样才能在二三张复写出内容来。同时,发票纸张的大小不是我们平常使用的A4纸,那我们就必须根据发票纸张的大小自定义纸张。
    因为发票的打印是一张发票的空白地方打印我们想要的东西,这就需要我们用CSS来控制打印的距离,可以用table或者div来实现打印内容的定位。在这中间可能会遇到问题,因为打印机都有默认的页边距,如果默认的页边距过大,我们在页面怎么调,可能打出来都对不上发票,所以必要的时候还要调一下页边距。当定位好了以后,要考虑发票的连续打印问题了,发票一般都是比A4要小,所以如果多张发票的内容放在页面上,不加以控制的话,打印出来可能只有第一张能对的上发票。我们使用一个CSS来控制打印的分页:.PageNext{page-break-after:always;}

    一般发票打印是把内容以及格式用js拼起来,然后放到一个Iframe里,再打印。


 function printActive(newstr){
  var headstr ='<html><head><title></title></head><body>';
  var footstr = '</body></html>';
  newstr = headstr + newstr + footstr;
  var ifr = document.createElement_x_x("iframe");//
新建iframe
    document.body.appendChild(ifr);           //
添加iframe
     var ifrdoc = ifr.contentWindow.document;
     //
命名
    ifr.name='i_frame';                       
     ifr.id='i_frame';
     ifrdoc.designMode = "on";   //
文档进入可编辑模式
    ifrdoc.open();              //
打开流
    ifrdoc.write(newstr);        //
写入内容
     ifrdoc.close();             //
关闭流
     ifrdoc.designMode ="off";   //
文档进入非可编辑模式
    setTimeout("printIframe()","1");    //
延迟1毫秒执行
 }

上面的Js就是一种方式,先创建一个Iframe,然后把要打印的内容写进去,在打印,因为这种打印一般会用到Ajax来从后台取数据,所以Js最后要延迟一毫秒执行,以保证打印的内容可以写进去。

 

重点: <OBJECT id=WebBrowser classid=CLSID:8856F961-340A-11D0-A96B-00C04FD705A2 height=0 width=0 VIEWASTEXT> </OBJECT> <input type=button value=打印 " class= "NOPRINT "> <input type=button value=直接打印 " class= "NOPRINT "> <input type=button value=页面设置 " class= "NOPRINT "> <input type=button value=打印预览 " class= "NOPRINT "> 注意: 1、CSS对打印的控制: <!--media=print 这个属性可以在打印时有效--> <style media=print> .Noprint{display:none;} .PageNext{page-break-after: always;} </style> Noprint样式可以使页面上的打印按钮等不出现在打印页面上,这一点非常重要,因为它可以用最少的代码完成最需要的功能 PageNext样式可以设置分页,在需要分页的地方 就OK了,呵呵 2、表格线粗细的设置,更是通过样式表: <style> .tdp { border-bottom: 1 solid #000000; border-left: 1 solid #000000; border-right: 0 solid #ffffff; border-top: 0 solid #ffffff; } .tabp { border-color: #000000; border-collapse:collapse; } </style> 或者: <style> .TdCs1 { border:solid windowtext 1.0pt; } .TdCs2 { border:solid windowtext 1.0pt; border-left:none; } .TdCs3 { border-top:none; border-left:solid windowtext 1.0pt; border-bottom:solid windowtext 1.0pt; border-right:solid windowtext 1.0pt; } .TdCs4 { border-top:none; border-left:none; border-bottom:solid windowtext 1.0pt; border-right:solid windowtext 1.0pt; } .underline { border-top-style: none; border-right-style: none; border-bottom-style: solid; border-left-style: none; border-bottom-color: #000000; } </style> 1、控制 "纵打 "、 横打”和“页面的边距。 (1) [removed] function SetPrintSettings() {  // -- advanced features  factory.printing.SetMarginMeasure(2) // measure margins in inches  factory.SetPageRange(false, 1, 3) // need pages from 1 to 3  factory.printing.printer = "HP DeskJet 870C "  factory.printing.copies = 2  factory.printing.collate = true  factory.printing.paperSize = "A4 "  factory.printing.paperSource = "Manual feed "  // -- basic features  factory.printing.header = "This is MeadCo "  factory.printing.footer = "Advanced Printing by ScriptX "  factory.printing.portrait = false  factory.printing.leftMargin = 1.0  factory.printing.topMargin = 1.0  factory.printing.rightMargin = 1.0  factory.printing.bottomMargin = 1.0 } [removed]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值