WEB前端打印使用记录
创始人
2025-06-01 20:29:57

一、window.print();

1、使用记录

printTable(){//获取body页面内容const bdhtml = window.document.body.innerHTML;//根据ID获取打印范围内容const jubuData = document.querySelector('#printcontent').innerHTML;//将打印内容赋给window bodywindow.document.body.innerHTML = jubuData;//对window body进行打印window.print();//重新给页面内容赋值;window.document.body.innerHTML = bdhtml;//重新加载window.location.reload();
}
@media print{.noprint{display: none;}
}
@page {size: auto;  //打印默认 横向 landscape  纵向 portraitmargin: 10mm 0 10mm 0; //打印外间距
}
@page :first {margin-top: 0mm;
}
@page { margin: 0; 
}

二、iframe.contentWindow.print();

1、使用记录

printEvent(){this.page2Flag = true;setTimeout(()=>{this.printTable();},300);
},
printTable(){//打印内容样式const printPageCss = '';//打印内容const prjBusinessPrintcontent = document.querySelector('#prjBusinessPrintcontent').innerHTML;const businessIframe = document.createElement('iframe');businessIframe.setAttribute('style', 'position: absolute; width: 0; height: 0;');document.body.appendChild(businessIframe);const prjBusinessIframeDoc = businessIframe.contentWindow.document;// 设置打印展示方式 - 纵向展示   portraitprjBusinessIframeDoc.write('');// 向 iframe 中注入 prjBusinessPrintcontent 样式// 新建link标签//const linkTag = document.createElement('link');// link标签引入css文件的地址//linkTag.href = '/static/luckysheet/css/businessView.css';// 设置link标签属性/*linkTag.setAttribute('rel', 'stylesheet');linkTag.setAttribute('media','print');linkTag.setAttribute('href','/static/luckysheet/css/businessView.css');*/prjBusinessIframeDoc.write(printPageCss);prjBusinessIframeDoc.write('
' + prjBusinessPrintcontent + '
');// 写入内容setTimeout(()=>{businessIframe.contentWindow.print();document.body.removeChild(businessIframe);this.page2Flag = false;}, 50); }

  @media print{.noprint{display: none;}}@page {size: portrait;  /* auto is the initial value */margin: 10mm 0 10mm 0; /* this affects the margin in the printer settings */}@page :first {margin-top: 0mm;}@page { margin: 0; }

 

三、总结

方法一方法二
优点简单,直接对打开页面进行打印;无需对打印页面再次进行样式渲染;

需对打印内容再次进行样式渲染,可精准控制样式;

不需要将打印内容重新在一个新页签显示,直接打印;

可多页打印;

WEB页面样式渲染可和打印页面样式分开单独处理;

缺点

打印会将打印内容重新加载到一个新的页签;

打印时存在只能打印一页,无法多页;(方法一未能解决此问题)

需程序控制在打印完时再次将旧内容还原并重新加载页面;

需单独渲染打印记录样式(未能解决此问题,可看后续记录)

1、打印分页

此标签后分页

此标签前分页

2、横向 纵向

@page {size: portrait;}  //纵向展示
@page {size: landscape;} //横向展示

3、link引入css文件到打印样式(未调试成功)

css文件放到vue项目中static文件夹下,地址访问成功,但是程序调试调用失败;

const iframeDoc = techIframe.contentWindow.document;// 设置打印展示方式 - 横向展示 landscape
// 新建link标签
const linkTag = document.createElement('link');
// link标签引入css文件的地址
linkTag.href = '/static/luckysheet/css/businessView.css';
// 设置link标签属性
linkTag.setAttribute('rel', 'stylesheet');
linkTag.setAttribute('media','print');
linkTag.setAttribute('href','/static/luckysheet/css/businessView.css');
iframeDoc.write(linkTag);// 向 iframe 中注入 printContent 样式

4、使用延时

setTimeout(()=>{techIframe.contentWindow.print();document.body.removeChild(techIframe);document.body.blur();
}, 50);

 上述()=>可在内容使用外部this对象;

setTimeout(function(){techIframe.contentWindow.print();document.body.removeChild(techIframe);document.body.blur();
}, 50);

function(){}无法在内部调用外部this对象;

相关内容

热门资讯

蚺怎么读(红尾蚺怎么读) 蚺怎... 本篇文章极速百科给大家谈谈蚺怎么读,以及红尾蚺怎么读对应的知识点,希望对各位有所帮助,不要忘了收藏本...
车载清洗汽车机好用吗(汽车清洗... 本篇文章极速百科给大家谈谈车载清洗汽车机好用吗,以及汽车清洗机器对汽车有好处吗对应的知识点,希望对各...
锐志2.5v马力多少匹?(锐志... 今天给各位分享锐志2.5v马力多少匹?的知识,其中也会对锐志25功率进行解释,如果能碰巧解决你现在面...
...列车时刻表查询,从大理到... 今天给各位分享...列车时刻表查询,从大理到丽江高铁火车最新消息的知识,其中也会对大理到丽江的高铁票...
天赋异禀什么意思,天生异禀是什... 天赋异禀什么意思目录天赋异禀什么意思天生异禀是什么意思天赋异禀是什么意思?天赋异禀是什么意思?禀字拼...
个人宣言简短,个人宣言简短有哪... 个人宣言简短目录个人宣言简短个人宣言简短有哪些?有什么可以作为座右铭,简洁有力的句子,用以激励自己求...
关于叶圣陶的资料(关于叶圣陶的... 本篇文章极速百科给大家谈谈关于叶圣陶的资料,以及关于叶圣陶的资料了解到了什么对应的知识点,希望对各位...
国徽的由来和象征意义(国徽的由... 今天给各位分享国徽的由来和象征意义的知识,其中也会对国徽的由来和象征意义100字进行解释,如果能碰巧...
夜天子第二季什么时候播,夜天子... 夜天子第二季什么时候播目录夜天子第二季什么时候播夜天子第二部什么时候播出CLANNAD的第二季什么时...
玄武岛怎么去,天龙玄武岛镜怎么... 玄武岛怎么去目录玄武岛怎么去天龙玄武岛镜怎么去天龙八部里的玄武岛到怎么走天龙八部里面的玄武岛,即圣兽...
绝世武神修为分为哪几个境界,绝... 绝世武神修为分为哪几个境界目录绝世武神修为分为哪几个境界绝世武神修为分为哪几个境界 绝世武神修为境界...
下线车是什么意思(下线车是什么... 今天给各位分享下线车是什么意思的知识,其中也会对下线车是什么意思可以买吗进行解释,如果能碰巧解决你现...
如何用usb连接音响,笔记本如... 如何用usb连接音响目录如何用usb连接音响笔记本如何连外置音箱?电脑音响怎么连接到电脑上?如何用u...
怎么在qq上设置密码锁,如何设... 怎么在qq上设置密码锁目录怎么在qq上设置密码锁如何设置qq密码锁怎么在登QQ设置密码怎样给QQ设置...
1英镑等于多少人民币,1英镑多... 1英镑等于多少人民币目录1英镑等于多少人民币1英镑多少人民币一英镑等于多少人民币100英镑等于多少人...
织围巾怎么收针(织围巾怎么收针... 本篇文章极速百科给大家谈谈织围巾怎么收针,以及织围巾怎么收针教程对应的知识点,希望对各位有所帮助,不...
2023中国国际商用车展(武汉... 本篇文章极速百科给大家谈谈2023中国国际商用车展(武汉车展)展览会时间表,以及武汉商用车展延期对应...
新鲜羊睪丸怎么做好吃,新鲜羊睪... 新鲜羊睪丸怎么做好吃目录吃羊睾丸害处 吃羊睾丸的功效作用新鲜羊睪丸怎么做好吃?羊睾丸叫什么菜名 吃羊...
重庆大学弘深学院如何,重庆大学... 重庆大学弘深学院如何目录重庆大学弘深学院如何重庆大学弘深班计算机怎么样通过本科评估的三本学校会怎么样...
标准正态分布表怎么使用,标准正... 标准正态分布表怎么使用目录标准正态分布表怎么使用标准正态分布表是如何使用的?请问:标准正态分布表的使...
斯巴鲁翼豹sti是后驱吗(斯巴... 本篇文章极速百科给大家谈谈斯巴鲁翼豹sti是后驱吗,以及斯巴鲁翼豹wrc对应的知识点,希望对各位有所...
矩阵的2次方怎么求,三阶矩阵的... 矩阵的2次方怎么求目录矩阵的2次方怎么求三阶矩阵的2次方怎么求题对2求一个矩阵次方怎么运算?如何计算...
怎么为人处事,怎么为人处事? ... 怎么为人处事目录怎么为人处事怎么为人处事?为人,处事,该怎么处,为人处事方式怎么为人处事 1....
如何为自己的QQ设置密保问题,... 如何为自己的QQ设置密保问题目录如何为自己的QQ设置密保问题qq怎么设置密保问题QQ怎么设置问题密保...
冉在名字中的意思,冉字取名什么... 冉在名字中的意思目录冉在名字中的意思冉字取名什么寓意谢杭冉这个名字的意思是什么冉在名字中的意思冉在名...
云和太阳有关的成语有哪些,有云... 云和太阳有关的成语有哪些目录云和太阳有关的成语有哪些有云有太阳成语带有云和日的成语有个太阳有很多 云...
基因表达的意义是什么,基因表达... 基因表达的意义是什么目录基因表达的意义是什么基因表达的意义是什么?什么是基因表达调控?基因表达调控有...
赵玉瑾结局是什么,将军在上赵玉... 赵玉瑾结局是什么目录赵玉瑾结局是什么将军在上赵玉瑾结局是什么 将军在上赵玉瑾结局介绍将军在上赵玉瑾结...
篮球记录表填写方法,如何填写篮... 篮球记录表填写方法目录篮球记录表填写方法如何填写篮球比赛记录表篮球比赛违反体育道德的犯规记录表上怎么...
阳澄湖大闸蟹做法有哪些,阳澄湖... 阳澄湖大闸蟹做法有哪些目录阳澄湖大闸蟹做法有哪些阳澄湖大闸蟹怎么吃?阳澄湖大闸蟹的吃法有哪些?阳澄湖...