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

  • 相关阅读:
    react-router刷新页面Cannot GET 问题
    react学习之弹出层
    react学习之js-xlsx导入和导出excel表格
    c#串口通信并处理接收的多个参数
    react与微信小程序
    promise知识点小结
    汇编命令小记
    Firebase-config 在android中的使用
    python:html元素解析
    Toast实现源码解析
  • 原文地址:https://www.cnblogs.com/liaoshiyong/p/3150836.html
Copyright © 2011-2022 走看看