错误的写法:

//打印
function printPage(areaId) {
if (parent.$("#PrinFrame").length == 0) {
parent.$("body").append('<iframe id="PrinFrame" style="display: none; "></iframe>');
} var prinFrame = parent.$("#PrinFrame")[0];
$(prinFrame).contents().find("body").html($("#" + areaId).html()); var win = prinFrame.contentWindow;
win.document.execCommand('Print');
}

错误原因:只把打印区域的内容放到iframe中,样式信息丢了。

改进后的写法:

//打印
function printPage(areaId) {
if (parent.$("#PrinFrame").length == 0) {
parent.$("body").append('<iframe id="PrinFrame" style="display: none; "></iframe>');
} var prinFrame = parent.$("#PrinFrame")[0];
var win = prinFrame.contentWindow;
$(prinFrame).attr("src", window.location.href);
$(prinFrame).load(function () {
$(prinFrame).contents().find("body").html($("#" + areaId).html());
win.document.execCommand('Print');
});
}

在iframe中重新加载当前页面,然后把body中的内容替换成待打印区域,这样iframe中保留了样式信息。

上面写法的缺点:多次点击打印按钮,iframe的load事件会被绑定多次;打印区域的大小超出A4纸范围;

再次改进后的写法:

//打印
function printPage(areaId) {
var prinFrame;
var win; if (parent.$("#PrinFrame").length == 0) {
parent.$("body").append('<iframe id="PrinFrame" style="display: none; "></iframe>');
prinFrame = parent.$("#PrinFrame")[0];
win = prinFrame.contentWindow; $(prinFrame).load(function () {
setTimeout(function () {
var html = '<table style="width:970px;"><tr><td>';
html += $("#" + areaId).html();
html += '</td></tr></table>';
$(prinFrame).contents().find("body").html(html);
win.document.execCommand('Print');
}, 100);
});
}
else {
prinFrame = parent.$("#PrinFrame")[0];
} $(prinFrame).attr("src", window.location.href);
}

再次改进后,确保iframe的load事件只被绑定一次;用宽度为970的table限制打印区域大小。

上面的写法还是有错误,重新打开tab页时,点击打印,不再进入iframe的load方法,再修改:

//打印
function printPage(areaId) {
if (parent.$("#PrinFrame").length == 0) {
parent.$("body").append('<iframe id="PrinFrame" style="display: none; "></iframe>');
} parent.$("#PrinFrame").attr("src", window.location.href); parent.$("#PrinFrame").one("load", function () {
setTimeout(function () {
var html = '<table style="width:970px;"><tr><td>';
html += $("#" + areaId).html();
html += '</td></tr></table>';
parent.$("#PrinFrame").contents().find("body").html(html);
parent.$("#PrinFrame")[0].contentWindow.document.execCommand('Print');
}, 100);
});
}

弄了一天,分页打印的时候还是有问题,如下图:

JS打印页面指定区域的更多相关文章

  1. js打印页面指定区域,并去掉页眉上的时间和请求路径

    需要通过js打印指定页面的内容 <style media=print type="text/css"> .noprint{visibility:hidden} < ...

  2. js打印div指定区域内容

    <script> function myPrint(obj){ var newWindow=window.open("打印窗口","_blank") ...

  3. 打印web页面指定区域的三种方法

    本文和大家分享一下web页面实现指定区域打印功能的三种方法,一起来看下吧. 第一种方法:使用CSS 定义一 个.noprint的class,将不打印的内容放入这个class内. 代码如下: <s ...

  4. vue 打印页面部分区域

    1. vue项目打印页面部分区域 2. 原生js实现页面局部打印功能 3. vue项目中将table组件导出Excel表格以及打印页面内容

  5. window.print()打印页面指定内容(使用iframe保证原页面不失效)

    使用window.print()时会出现两个问题: (1)直接使用window.print() 打印的是整页内容-->无法实现打印指定区域 (2)打印时替换body中的内容,打印完成后再替换回来 ...

  6. JavaScript之打印页面局部区域

    /** * [print part area of html page] * @Author JohnnyZen * @DateTime 2017-10-23 * @copyright [johnny ...

  7. JS打印页面

         打印 整个html页面(PS:样式要写在页面里面才能打印(就是用内部样式))             <a id="dayi" runat="server ...

  8. js 获取页面可视区域宽高

    获取浏览器窗口的可视区域高度和宽度,滚动条高度有需要的朋友可参考一下. 1.IE中,浏览器显示窗口大小只能以下获取: 代码如下复制代码 代码如下 document.body.offsetWidth d ...

  9. js打印html指定元素,解决动态获取的图片无法打印问题

    用js来调用浏览器的打印接口很容易,一两行代码就能搞定,但是有些数据是通过动态生成的,例如一些动态生成的二维码,有时候调用打印接口图片会无法显示 为了解决这个问题,建议使用下面这个库 下载:https ...

随机推荐

  1. 移动App开发需要更多的PaaS平台而不是IaaS

    时代的变迁,创业的大潮,越来越多的人关注了有点开发,越来越多的人了解了互联网服务术语:PaaS.IaaS.SaaS.BaaS等.今天大家在开发App的时候这么多复杂的云服务如何来选择呢? IaaS服务 ...

  2. Unity3D热更新全书-重头再来

    之前写了Unity3D热更新全书系列Blog 提出了下载.加载.脚本三个方面的开源类库 下载方面有EasyDown加载方面有GameObjParser脚本方面有C#Light另外有一个没有独立成库,但 ...

  3. SQL Server 性能优化之——T-SQL TVF和标量函数

    阅读导航 1. TVF(表-值行数Table-Valued Functions)         a. 创建TVF         b. 使用TVF的低性能T-SQL         c. 使用临时表 ...

  4. Unity3D使用经验总结 缺点篇

    不论是从官方手册,还是各种第三方教程,几乎涉及到的,都是讲如何使用U3D,以及U3D的优点. 虽然我是用的一个让步语气,但请不要否认U3D的这些优点,它们的确存在. 但对于一个引擎的特性来说,优点与缺 ...

  5. Java程序员的日常 —— 《编程思想》持有对象

    集合框架可以说是Java里面必备的知识点了,日常的使用中也会遇到各种情况需要使用到集合.下面就简单介绍下各种集合的使用场景: List List可以看做是数组,实现的方式有两种: ArrayList ...

  6. Atitit 贝叶斯算法的原理以及垃圾邮件分类的原理

    Atitit 贝叶斯算法的原理以及垃圾邮件分类的原理 1.1. 最开始的垃圾邮件判断方法,使用contain包含判断,只能一个关键词,而且100%概率判断1 1.2. 元件部件串联定律1 1.3. 垃 ...

  7. 每天一个linux命令(8):cp 命令

    cp命令用来复制文件或者目录,是Linux系统中最常用的命令之一.一般情况下,shell会设置一个别名,在命令行下复制文件时,如果目标文件已经存在,就会询问是否覆盖,不管你是否使用-i参数.但是如果是 ...

  8. python2.7和python3共存

    python2.7和python3共存 原本装了python,玩nodejs的时候需要node-gyp来编译依赖,无赖这货需要python2.5<v<3.0,那就弄两个版本吧 转载自 ht ...

  9. TSQL order by 子句中排序列的多种写法

    Order by 子句用于对结果进行排序,执行顺序位于select子句之后,排序列有4中写法: column_name column_alias,由于order by子句的执行顺序位于select子句 ...

  10. WPF中找不到Image或者Image不是Drawing系列

    WPF中默认没有引用WinForm里面的一些东西,都是用它自带的那一套,但又不能完全脱离,所以有的时候比较蛋疼