JS实现页面打印(整体、局部)

作者:小果子_G 时间:2024-04-26 17:14:27 

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

方式一:window.print()

整体打印


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

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

局部打印

首先,在html中,通过star和end来标记打印区域


<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()的方式进行打印的,而这个插件在其基础上进行了进一步的封装,可以轻松实现打印网页上的某个区域,这是个亮点。

参考网址:https://www.aspxhome.com/article/102230.htm

请注意!很多朋友遇到 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底层打印,报安全警告,不建议使用(不支持局部打印)

这里只介绍两种方式,希望对大家的学习有所帮助,也希望大家多多支持ASP之家。

来源:http://www.jianshu.com/p/40dfd2d6c344?utm_source=tuicool&utm_medium=referral

标签:Javascript,页面,打印
0
投稿

猜你喜欢

  • 在Python中使用M2Crypto模块实现AES加密的教程

    2022-09-29 17:43:59
  • mysql单字段多值分割和合并的处理方法

    2024-01-16 23:49:00
  • 适合各种浏览器的js拖动层

    2007-10-22 22:43:00
  • Python Vaex实现快速分析100G大数据量

    2021-05-24 08:48:58
  • Js setInterval与setTimeout(定时执行与循环执行)的代码(可以传入参数)

    2024-04-16 09:23:29
  • mysql修复数据表的命令方法

    2024-01-24 10:15:33
  • Python 私有化操作实例分析

    2022-11-06 05:44:42
  • Go中的条件语句Switch示例详解

    2024-05-09 10:11:25
  • Python selenium模块实现定位过程解析

    2021-01-10 10:50:27
  • python编写的最短路径算法

    2021-01-15 20:54:14
  • 一篇文章搞定Mysql日期时间函数

    2024-01-20 19:32:58
  • asp如何刪除客户端的Cookies?

    2010-05-18 18:25:00
  • python 找出list中最大或者最小几个数的索引方法

    2022-08-12 13:23:11
  • sqlserver主键自增的实现示例

    2024-01-16 22:41:10
  • python实现计算图形面积

    2021-06-01 06:18:54
  • vue如何使用rem适配

    2024-04-30 08:44:49
  • js自动闭合html标签(自动补全html标记)

    2023-08-25 07:06:35
  • Python数据可视化之Pyecharts使用详解

    2022-10-19 17:31:12
  • 揭开HTML 5工作草稿的神秘面纱

    2008-02-13 08:25:00
  • 在Keras中CNN联合LSTM进行分类实例

    2023-10-12 22:07:07
  • asp之家 网络编程 m.aspxhome.com