JS实现页面打印

作者: m_gyf | 来源:发表于2017-08-17 17:02 被阅读1964次

    我们在网页开发过程中经常会有打印页面的需求,通过JS来实现的方法有很多,这里我做了一个整理,供大家参考。

    方式一:window.print()


    整体打印

    <a href="javascrīpt:window.print()" target="_self">打印</a>
    

    现在就轻松实现了页面的打印,但是这种方式会将整个页面打印,如果想要实现指定区域的打印需要通过下面的设置

    局部打印

    首先,在html中,通过starend来标记打印区域

    <h1>这块内容不需要打印</h1>
    <!--startprint-->
    <div class="content">
        这里是需要打印的内容
            .....
    </div>
    <!--endprint-->
    <h1>这块内容不需要打印</h1>
    

    然后,在点击事件中添加如下代码

    function doPrint() {      
            bdhtml=window.document.body.innerHTML;      
            sprnstr="<!--startprint-->";      
            eprnstr="<!--endprint-->";      
            prnhtml=bdhtml.substr(bdhtml.indexOf(sprnstr)+17);      
            prnhtml=prnhtml.substring(0,prnhtml.indexOf(eprnstr));      
            window.document.body.innerHTML=prnhtml;   
            window.print();      
    }   
    

    过滤打印区域的内容

    例如

    <!--startprint-->
    <div class="content">
        <button class="noprint">预览</button>
        <button class="noprint">打印</button>
          这里是需要打印的内容
            .....
        </div>
    <!--endprint-->
    

    上面的预览和打印按钮不希望打印,如果要过滤的话可以做下面的样式设置

            <style type="text/css">
                @media print {
                    .noprint{
                        display: none;
                    }
                }
            </style>
    

    or

            <style type="text/css" media="print">
                .noprint{
                    display: none;
                }
            </style>
    

    两种写法任选其一

    分页打印

    使用 window.print() 打印时,如果内容超出会自动分页。但是我们如果需要自定义分页范围,如碰到表格分页打印,可以进行如下设置:

    <table width="100%"  border="0" cellpadding="0" cellspacing="0"  style="page-break-after:always" > 
    </table>
    

    方式二、jqprint()


    jqprint是一个基于jQuery编写的页面打印的一个小插件,但是不得不承认这个插件确实很厉害,最近的项目中帮了我的大忙,在Web打印的方面,前端的打印基本是靠window.print()的方式进行打印的,而这个插件在其基础上进行了进一步的封装,可以轻松实现打印网页上的某个区域,这是个亮点。

    点击下载

    请注意!很多朋友遇到 Cannot read property 'opera' of undefined 错误问题是juqery版本兼容问题
    解决方法:加入迁移辅助插件 jquery-migrate-1.0.0.js可解决版本问题

    引入

    <script language="javascript" src="jquery-1.4.4.min.js"></script>
    <script language="javascript" src="jquery.jqprint-0.3.js"></script>
    

    js

    <script language="javascript">
    function  a(){
            $("#ddd").jqprint();
        }
    </script>
    

    html

    <div id="ddd">
        <table>
            <tr>
                <td>test</td>
                <td>test</td>
                <td>test</td>
                <td>test</td>
                <td>test</td>
            </tr>
        </table>
    </div>
    <input type="button" onclick=" a()" value="打印"/>
    

    设置模板打印

    $("#printContainer").jqprint({
         debug: false, //如果是true则可以显示iframe查看效果(iframe默认高和宽都很小,可以再源码中调大),默认是false
         importCSS: true, //true表示引进原来的页面的css,默认是true。(如果是true,先会找$("link[media=print]"),若没有会去找$("link")中的css文件)
         printContainer: true, //表示如果原来选择的对象必须被纳入打印(注意:设置为false可能会打破你的CSS规则)。
         operaSupport: true//表示如果插件也必须支持歌opera浏览器,在这种情况下,它提供了建立一个临时的打印选项卡。默认是true
    });
    

    附言


    另外还可以使用html 标签<object>引入Webbrowser控件(只兼容IE)或者调用windows底层打印,报安全警告,不建议使用(不支持局部打印)

    这里只介绍两种方式,如果在使用的过程中有任何问题,可以留言讨论。

    相关文章

      网友评论

      • 恬雅过客:现在有个合同需要打印,需要在合同的每个打印页顶部加上一个合同条形码,请问怎么加?
      • 简博Simbo:web客户端打印,完美解决中文打印问题,无插件,无弹窗,有源码
        https://www.jianshu.com/p/d6073a3f7af3
      • d9b8f0c0bc9b:请问怎么设置打印字体大小
      • JsLin_:那个window.print 不可以跳转 有没有办法手写让其跳转 还有就是单页面开发的时候用打印功能,取消了整个页面就不能操作了,不知道你有没有发现。那个插件是可以跳转的
        m_gyf:在点击事件里操作效果是跟插件一样的,不过页面样式复杂的话window.print()取消之后会改变页面样式,插件不会。
      • 一定要爱你所做:写的代码都这么漂亮
      • desire33:棒棒的

      本文标题:JS实现页面打印

      本文链接:https://www.haomeiwen.com/subject/vpdgrxtx.html