window.print()

print() 方法用于打印当前窗口的内容。谷歌调用 print() 方法会产生一个打印预览弹框,让用户可以设置打印请求。

但谷歌貌似不能自定义设置页眉页脚的文字;ie和火狐可以,如下所示

火狐:菜单-->打印

ie:文件-->打印预览,样子和上面差不多

使用或编辑打印样式的几种方式:

引入样式表

<link href="/path/print.css" media="print" rel="stylesheet" />
@import url("/path/print.css") print;

媒体查询:

@media print {
h1 {
font-size: 20px;
color: red;
}
}
<style type="text/css" media="print">
// 打印样式
</style>

设置打印纸张的外边距(去掉页眉页脚):

@page{margin:2cm 3cm;}  margin若设为0,页眉页脚默认去掉了;

 
设置分页:在外层盒子上加上css:page-break-after:always;
 

打印方案:

方案一:打印指定页面区域,将指定区域dom赋值给全局innerHTML,简单粗暴;但由于打印后回到页面,页面元素卡主,无法操作,需要刷新;

function printpage(id){
var newstr = document.getElementById(id).innerHTML;
var oldstr = document.body.innerHTML;
document.body.innerHTML = newstr;
window.print();
document.body.innerHTML = oldstr;
window.location.reload() // 若不刷新,打印后页面无法操作
}

方案二:新开一个窗口,不会有刷新后返回页面无法操作问题,但不方便设置调试分页,布局样式之类的

const printWindow = window.open()
printWindow.document.write(document.getElementById('printDiv')).innerHTML
printWindow.print()
printWindow.close()

方案三:在本页面新建iframe,不会有刷新后返回页面无法操作问题;目前用的这种;

代码中打印的css 需要将之前所有是px 的单位改为 pt ,包括border;我之前设置border:1px 打印时火狐下表格的边框有的显示了,有的显示很浅;

代码中注释地方也需要注意一下

let printHtml = document.getElementById('printDiv').innerHTML
let iframe = document.createElement('iframe') // ie下打印时,iframe会在页面中闪一下,所以设置推出屏幕外
iframe.setAttribute('style','position:absolute;width:0px;height:0px;left:-500px;top:-500px;') let ieStr = '' // 设置ie下的样式,同样设置的字体大小为18pt,ie下打印出来显示的更大,行高也是;ie下需要设置小一点
if('ActiveXObject' in window){
ieStr = 'HTML,body,div{font-size:13pt;}'+
'.lineHeight{line-height:28pt;}'
}else{
ieStr = 'HTML,body,div{font-size:18pt;}'+
'.lineHeight{line-height:40pt;}'
} // 设置样式
// 注意点:设置了浮动元素一定要清除浮动;不然打印元素排版异常;浮动元素清除了浮动还异常则不用浮动;试试display:inline-block;
let style = '<style>'+
ieStr+
'@page{margin:2cm 3cm;}'+
// ···
// ···
// ···
'</style>' document.body.appendChild(iframe)
iframe.contentDocument.write(style+printHtml)
iframe.contentDocument.close() // 加延时是为了解决火狐下,打印按钮点击一次没反应,需要连续点击好多下才出个弹框提示是否阻止弹框的内容出现;
iframe.contentWindow.onload = setTimeout(() =>{
iframe.contentWindow.focus() // 兼容ie,不加这句ie默认打印还是全部的网页,不是局部创建的iframe
iframe.contentWindow.print()
document.body.removeChild(iframe)
},0)

下面两张图分别是 样式没完全用pt  和 完全用pt 且浏览器做兼容的对比

批量打印

  我这里处理的比较简单粗暴,一般批量打印的数据不会太多,几十条左右,表格的一页;将要打印的几十条数据提前展示并display:none;

  然后 let printHtml = document.getElementById('批量打印的盒子').innerHTML,执行上面的打印方法;

方案四:设计复杂的打印页面建议用插件;比如打印票据,包含图片,二维码的页面;可以使用hiprint;

参考 https://github.com/alexwjj/vue-iframe-print

使用window.print进行前端打印,批量打印,设置分页,ie、火狐下设置页眉页脚的更多相关文章

  1. 使用window.print()后,未关闭打印页面,原网页不能操作

    使用window.print()后,未关闭打印页面,原网页不能操作,此时可以试着用window.location.reload()重新加载页面解决问题.

  2. 关于JavaScript打印去掉页眉页脚

    因为这个问题,Google和百度都查了个遍,网上主要解决方案都是这一个代码: <script language="JavaScript"> var hkey_root, ...

  3. 使用js打印时去除页眉页脚

    写在前面 今天的开发遇到了使用window.print()功能进行当前页面打印的功能,因为页脚左边部分显示了url,这是不能存在的,已解决,写在这里. 正文 很多网上的方法都是不能用的,最后我找到一个 ...

  4. js中window.print()去除页眉页脚

    //jsp打印时去除页眉页页脚 打印前加入下面代码即可 var HKEY_Root,HKEY_Path,HKEY_Key; HKEY_Root="HKEY_CURRENT_USER" ...

  5. IE浏览器打印的页眉页脚设置解决方法

    首先说明问题: 默认情况下,通过IE的打印对话框,打印出来的内容都有页眉和页脚的. 查看ie的页面设置发现如右图中,页眉页脚 下面先说明&w&bPage&p of &P ...

  6. window.print() 去掉页眉页脚及打印链接【转载】

    页面中添加样式: <style media="print"> @page { size: auto; /* auto is the initial value */ m ...

  7. 【转】jqprint打印时自定义页眉页脚

    需求:自定义页眉,实现打印时分页时每页页眉都显示相同的信息 打印所用插件jqprint 解决方法: <div class="divHeader"> <span s ...

  8. C#操作word的一些基本方法(word打印,插入文件,插入图片,定位页眉页脚,去掉横线)

    Microsoft.Office.Interop.Word.Application wordApp = new ApplicationClass() word对象 2. Microsoft.Offic ...

  9. js打印去掉页眉页脚

    <style type="text/css" media="print"> @page /* 实现代码 */ { size: auto; /* au ...

  10. 用window.print()打印如何去掉页眉和页脚

    用window.print()打印如何去掉页眉和页脚 2007-07-12 11:44:52|  分类: javascript 知识|举报|字号 订阅     <script language= ...

随机推荐

  1. HDU-3032--Nim or not Nim?(博弈+SG打表)

    题目分析: 这是一个经典的Multi-SG游戏的问题. 相较于普通的Nim游戏,该游戏仅仅是多了拆成两堆这样的一个状态.即多了一个SG(x+y)的过程. 而根据SG定理,SG(x+y)这个游戏的结果可 ...

  2. 领域驱动设计(DDD)实践之路(四):领域驱动在微服务设计中的应用

    这是"领域驱动设计实践之路"系列的第四篇文章,从单体架构的弊端引入微服务,结合领域驱动的概念介绍了如何做微服务划分.设计领域模型并展示了整体的微服务化的系统架构设计.结合分层架构. ...

  3. 【驱动】SPI驱动分析(三)-SPI关键数据类型

    SPI数据类型 SPI控制器驱动结构体 struct spi_master抽象了控制器硬件,在SoC中的指的就是内部SPI控制器,当向SPI核心层注册一个SPI控制器时就需要提供这样的一个结构体变量. ...

  4. 实时渲染前沿研究:在浏览器上实现了Facebook提出的DLSS算法

    大家好,我基于WebNN在浏览器上实现了2020年Facebook提出的Neural-Supersampling-for-Real-time-Rendering算法.它是一个用于实时渲染的神经网络超采 ...

  5. ASP.Net Core 5.0 MVC log4net日志的添加

    1. 引入程序集 Microsoft.Extensions.Logging.Log4Net.AspNetCore 及 log4net 2. 添加配置文件log4net.Config,  并将属性改为& ...

  6. java基础-数组-day06

    1. 引入数组 录入10个学生的成绩 求和 求平均 import java.util.Scanner; public class TestArray01{ public static void mai ...

  7. 每天学五分钟 Liunx 001 | 用户及用户组

    Liunx 文件权限 [root@controller-0 ~]# ll -al heihei -rw-r--r--. 1 root root 0 Mar 3 07:39 heihei 第一列 -rw ...

  8. Oceanbase开源版 数据库恢复MySQL数据库的过程

    # Oceanbase开源版 数据库恢复MySQL数据库的过程 背景 想进行一下Oceanbase数据库的兼容性验证. 想着用app create 数据库的方式周期比较长. 所以我想着换一套 备份恢复 ...

  9. [转帖]oracle 11.2.0.4 rac集群等待事件enq: TM - contention

    近期,一金融客户oracle 11.2.0.4 rac集群delete不当导致等待事件enq: TM - contention严重引起大范围会话堆积,记录的相关分析工作如下. 1.登录集群任意节点,查 ...

  10. [转帖]12.24.2 DECIMAL Data Type Characteristics

    https://dev.mysql.com/doc/refman/8.0/en/fixed-point-types.html This section discusses the characteri ...