html 打印相关操作与实现详解

2023-12-01 0 221

原理为调用 window.print() 方法,但是该方法只能对当前页面全部打印,所以有了以下方案来解决局部打印

1: 利用 iframe 将需要打印的元素和样式注入 再调用打印

// 示例代码
function print () {
let ifElement = document.getElementById(\’ifId\’)
const addHtmlPrint = () => {
const content = ifElement.contentWindow || ifElement.contentDocument
content.document.body.innerHTML = this.detailTable
const styleEle = document.createElement(\’style\’)
/* 去掉打印时的页头和页脚 */
styleEle.innerHTML = \’@media print {@page { margin: 5mm; }}\’
content.document.getElementsByTagName(\’head\’)[0].appendChild(styleEle)

/* 保障 iframe 中资源加载完成,图片要用 img 形式引入 */
ifElement.onload = () => {
content.print()
}
}
this.getDetailTable()

if (ifElement) {
// 若已经创建,则直接打印
addHtmlPrint()
} else {
ifElement = document.createElement(\’iframe\’)
ifElement.setAttribute(\’id\’, \’ifId\’)
ifElement.setAttribute(\’style\’, \’display:none\’)
document.body.appendChild(ifElement)

addHtmlPrint()
}
}

2: 利用 @media print,在当前页面设置打印操作时需要隐藏的元素

@media print{
/* 这里将不需要打印的元素设置为不显示 */
.hidden-element{
display:none;
/* visibility:hidden; */
}
/*纸张设置为宽1200px 高800px*/
@page{
size:1200px 800px;
}
}

  • <link href="/example.css" media="print" rel="stylesheet" /> 标注打印时才会采用的样式
  • 监听打印事件 window.addEventListener(\’beforeprint|| afterprint\’, ()=> {});

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持悠久资源网。

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

悠久资源 HTML/Xhtml html 打印相关操作与实现详解 https://www.u-9.cn/sheji/html/8921.html

常见问题

相关文章

发表评论
暂无评论
官方客服团队

为您解决烦忧 - 24小时在线 专业服务