前端打印实现-全网最简单实现方法

1.前言

这两天项目中遇到一个打印的功能,对表格数据打印,并且表格的footer底部内容是用户手动输入的。由于是第一次做打印功能我上网搜了一些方案比如:1.直接通过window.print()打印如图

这种方式存在弊端就是他会替换dom元素打印但是对应通过类名引入样式是无法生效的,就是只能把样式写到style里面,如果样式很多就不方便。 2.创建一个Iframe标签然后把打印元素放进去也可以实现打印,但是同上面的一样通过类名引入的样式不生效。

html 复制代码
    <div id="printId">
        打印内容
        <h1 class="h1color">颜色变化</h1>
    </div>
    <script>
        let bth = document.querySelector('button')
        bth.addEventListener('click', onIframePrint)
        function onIframePrint() {
            const printContentHtml = document.getElementById("printId").innerHTML;
            const iframe = document.createElement("iframe");
            document.body.appendChild(iframe);
            iframe.contentDocument.write(printContentHtml);
            iframe.contentDocument.close();
            iframe.contentWindow.print();
            document.body.removeChild(iframe);
        }

2.我的解决方案

这种方式就是对HTML和CSS进行拼接,这样引入的CSS就可以生效。并且的打印的文本可以让用户手动输入一部分最后将值打印出来,相比之前的解决方案更加灵活。

js 复制代码
  function innerHtmlPrint() {
    // 创建打印专属样式
    const printStyles = `
            <style>
                body {
                    background: white;
                    font-family: Arial, sans-serif;
                    margin: 0;
                    padding: 10mm;
                    -webkit-print-color-adjust: exact;
                    print-color-adjust: exact;
                }
                .print-header {
                    margin-bottom: 10mm;
                }
                table {
                    width: 100%;
                    border-collapse: collapse;
                    table-layout: fixed;
                    font-size: 9px;
                 }
  
            </style> `;
    // 获取打印内容
    const printContent = document.querySelector('.printcontent')?.innerHTML;
    // 创建打印文档
    const printDocument = `
            <!DOCTYPE html>
            <html>
                <head>
                    ${printStyles}
                </head>
                <body>
                   <h4 style={{ fontWeight: 500 }}>${parentData.batchName}</h4>
                    ${printContent}
                   <div class="printFooter">
                        <span>技术员:${printData.technician}</span>
                        <span>配矿人:${printData.miner}</span>
                        <span>生成技术部:${printData.techDept}</span>
                        <span>焙烧制酸厂:${printData.acidPlant}</span>
                      </div>
                    <script>
                        window.onload = function() {
                            window.print();
                            setTimeout(function() {
                                window.close();
                            }, 100);
                        }
                    </script>
                </body>
            </html>
        `;
    // 打开打印窗口
    const printWindow = window.open('', '_blank');
    if (printWindow) {
      printWindow.document.write(printDocument);
      printWindow.document.close();
    }
  }

3.打印样式优化手段

对打印来说最头疼的就是对样式的优化,有时候在页面写好的样式在打印的时候就会有些问题。

1.@print 通过CSS每天查询@print修改样式

css 复制代码
<style>
@media print {
  body {
    background: white;
    font-family: Arial, sans-serif;
    margin: 0;
    padding: 10mm;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }
  /* 其他打印专属样式 */
}
</style>

2.@Page

@page at 规则是一种 CSS 规则,用于修改打印页面的不同方面。它的目标是修改页面的尺寸、方向和页边距。@page at 规则可用于针对打印输出中的所有页面,也可使用其各种伪类来针对一个子集。

其他

在询问AI的过程中提到了这样一个样式,可以解决表格跨页显示的问题,这个我没有试过不知道行不行。

相关推荐
一 乐27 分钟前
民宿|基于java的民宿推荐系统(源码+数据库+文档)
java·前端·数据库·vue.js·论文·源码
testleaf1 小时前
前端面经整理【1】
前端·面试
好了来看下一题1 小时前
使用 React+Vite+Electron 搭建桌面应用
前端·react.js·electron
啃火龙果的兔子1 小时前
前端八股文-react篇
前端·react.js·前端框架
小前端大牛马1 小时前
react中hook和高阶组件的选型
前端·javascript·vue.js
刺客-Andy1 小时前
React第六十二节 Router中 createStaticRouter 的使用详解
前端·javascript·react.js
秋田君2 小时前
深入理解JavaScript设计模式之策略模式
javascript·设计模式·策略模式
萌萌哒草头将军3 小时前
🚀🚀🚀VSCode 发布 1.101 版本,Copilot 更全能!
前端·vue.js·react.js
GIS之路3 小时前
OpenLayers 图层叠加控制
前端·信息可视化
90后的晨仔3 小时前
ArkTS 语言中的number和Number区别是什么?
前端·harmonyos