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


Posted in Javascript onAugust 18, 2017

我们在网页开发过程中经常会有打印页面的需求,通过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://3water.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底层打印,报安全警告,不建议使用(不支持局部打印)

这里只介绍两种方式,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
谈谈js中的prototype及prototype属性解释和常用方法
Nov 25 Javascript
jQuery 获取页面li数组并删除不在数组中的key
Aug 02 Javascript
javascript 动态样式添加的简单实现
Oct 11 Javascript
JS基于面向对象实现的选项卡效果示例
Dec 20 Javascript
vue中post请求以a=a&amp;b=b 的格式写遇到的问题
Apr 27 Javascript
Vue中的异步组件函数实现代码
Jul 20 Javascript
webpack配置proxyTable时pathRewrite无效的解决方法
Dec 13 Javascript
JavaScript中工厂函数与构造函数示例详解
May 06 Javascript
微信小程序云开发如何实现数据库自动备份实现
Aug 16 Javascript
微信小程序模板消息限制实现无限制主动推送的示例代码
Aug 27 Javascript
layui下拉框获取下拉值(select)的例子
Sep 10 Javascript
Antd-vue Table组件添加Click事件,实现点击某行数据教程
Nov 17 Javascript
简单实现jQuery轮播效果
Aug 18 #jQuery
JavaScript编写的网页小游戏,很给力
Aug 18 #Javascript
ReactJs实现树形结构的数据显示的组件的示例
Aug 18 #Javascript
基于 Vue 的树形选择组件的示例代码
Aug 18 #Javascript
简单实现jQuery手风琴效果
Aug 18 #jQuery
JavaScript中Hoisting详解 (变量提升与函数声明提升)
Aug 18 #Javascript
JavaScript实现旋转轮播图
Aug 18 #Javascript
You might like
5款Javascript颜色选择器
2009/10/25 Javascript
基于jQuery的烟花效果(运动相关)点击屏幕出烟花
2012/06/14 Javascript
js控制不同的时间段显示不同的css样式的实例代码
2013/11/04 Javascript
JavaScript实现的石头剪刀布游戏源码分享
2014/08/22 Javascript
一个JavaScript操作元素定位元素的实例
2014/10/29 Javascript
Node.js的包详细介绍
2015/01/14 Javascript
jquery实现向下滑出的二级导航下滑菜单效果
2015/08/25 Javascript
nodejs实现bigpipe异步加载页面方案
2016/01/26 NodeJs
jQuery 3.0十大新特性最终版发布
2016/07/14 Javascript
JS 实现导航菜单中的二级下拉菜单的几种方式
2016/10/31 Javascript
详解Angular中的自定义服务Service、Provider以及Factory
2017/04/22 Javascript
JavaScript之Map和Set_动力节点Java学院整理
2017/06/29 Javascript
JS库之Three.js 简易入门教程(详解之一)
2017/09/13 Javascript
vue.js input框之间赋值方法
2018/08/24 Javascript
jquery实现聊天机器人
2020/02/08 jQuery
uni-app从安装到卸载的入门教程
2020/05/15 Javascript
vue-admin-template配置快捷导航的代码(标签导航栏)
2020/09/04 Javascript
使用jquery实现轮播图效果
2021/01/02 jQuery
Python程序设计入门(2)变量类型简介
2014/06/16 Python
pandas pivot_table() 按日期分多列数据的方法
2018/11/16 Python
详解Python Matplot中文显示完美解决方案
2019/03/07 Python
python实现比较类的两个instance(对象)是否相等的方法分析
2019/06/26 Python
Python列表嵌套常见坑点及解决方案
2020/09/30 Python
CSS的pointer-events属性详细介绍(作用和注意事项)
2014/04/23 HTML / CSS
北美主要的汽车零部件零售商:AutoShack.com
2019/02/23 全球购物
Keds加拿大官网:购买帆布运动鞋和皮鞋
2019/09/26 全球购物
乌克兰的第一家手表店:Deka
2020/03/05 全球购物
买房子个人收入证明
2014/01/16 职场文书
贷款担保书范文
2014/05/13 职场文书
2014年学校工作总结
2014/11/20 职场文书
社区法制宣传日活动总结
2015/05/05 职场文书
大国崛起日本观后感
2015/06/02 职场文书
五一放假通知怎么写
2015/08/18 职场文书
《水上飞机》教学反思
2016/02/20 职场文书
python制作图形界面的2048游戏, 基于tkinter
2021/04/06 Python
python中pd.cut()与pd.qcut()的对比及示例
2022/06/16 Python