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