web打印的几种方法(2023)

在工作中出现web打印的情况是非常多的,其实这也是一个比较烦人的问题,这篇博客整理一下关于Web打印的一些方法或者方式。

  1. window.print()

这个方法是用来打印网页的,页面上的其他的元素也会被打印处理,在打印的时候页眉页脚是不太好控制的。

所以如果使用这种方法的话最好将结果放到两个注释中间,之后通过JS来实现打印区域的功能。

具体做法:


         
     

 
 
bdhtml=window.document.body.innerHTML;
sprnstr=“ ”;
eprnstr=“ ”;
prnhtml=bdhtml.substr(bdhtml.indexOf(sprnstr)+17);
prnhtml=prnhtml.substring(0,prnhtml.indexOf(eprnstr));
window.document.body.innerHTML=prnhtml;
window.print();

特别注意:使用window.print方法是不能够打印IE浏览器中的移动或者旋转的动画的,但是在非IE浏览器中是可以支持的。

  1. Jquery打印

下面一个是用Jquery框架写的一个web打印控件的功能。

代码如下:

(function ($) {
    var printAreaCount = 0;
    $.fn.printArea = function () {
        var ele = $(this);
        var idPrefix = “printArea_”;
        removePrintArea(idPrefix + printAreaCount);
        printAreaCount++;
        var iframeId = idPrefix + printAreaCount;
        var iframeStyle = ‘position:absolute;width:0px;height:0px;left:-500px;top:-500px;’;
        iframe = document.createElement(‘IFRAME’);
        $(iframe).attr({
            style: iframeStyle,
            id: iframeId
        });
        document.body.appendChild(iframe);
        var doc = iframe.contentWindow.document;
        $(document).find(“link”).filter(function () {
            return $(this).attr(“rel”).toLowerCase() == “stylesheet”;
        }).each(
                function () {
                    doc.write(‘<link type=“text/css” rel=“stylesheet” href="’
                            + $(this).attr(“href”) + ‘" >’);
                });
        doc.write(‘<div class="’ + $(ele).attr(“class”) + ‘">’ + $(ele).html()
                + ‘’);
        doc.close();
        var frameWindow = iframe.contentWindow;
        frameWindow.close();
        frameWindow.focus();
        frameWindow.print();
    }
    var removePrintArea = function (id) {
        $(“iframe#” + id).remove();
    };
})(jQuery);
 
 

要打印的内容区域
 
  1. HttpPrinter控件

HttpPrinter打印控件,界面大方、使用简单、但无签名,支持打印预览、直接打印,可设置页眉、页脚、页边距、打印份数、纸张大小等信息。

这个控件的下载地址为:http://www.HttpPrinter.com/

  1. 6612345免费网页打印浏览器- 一个集网页打印 网页拍照 报表打印 串口读取 为一体的 超级浏览器
     
    官方的介绍是这样的:
    6612345免费网页打印浏览器
    本软件完全免费,这是一个集网页打印、读取身份证、拍照、读取串口等功能为一体的超级浏览器。

支持如下功能特点:

  1. 支持网页静默打印,只要一句js即可;

  2. 拖拽即可完成设计,支持 fastreport, reportmachine, gridreport

  3. 强大的报表功能,管它什么报表, 交叉的,嵌套的,还是二维码,图片等等,都支持.

  4. 打印机:只要是能用的打印机,都支持,针式打印机、激光打印机、小票打印机,证卡打印机等等,都不在话下,而且当有多个打印机时可以指定打印机;

  5. 支持web拍照.

  6. 支持读取身份证设备 ( 普天 新中新 神思 精伦 ).

  7. 支持pdf静默打印

  8. 支持图片打印

  9. 支持串口通讯

  10. 多语言支持:中文简体,中文繁体,英语,法语,德语,意大利语,日语,韩语,葡萄牙语,俄语,西班牙语.

技术支持QQ群:481305703

下载地址
https://share.weiyun.com/QLXONNpx

其实关于打印控件还有很多,找到自己最合适的才是硬道理,如果还有更多的web打印实现方法,可以给我留言。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值