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最后要延迟一毫秒执行,以保证打印的内容可以写进去。