news 2026/4/21 5:19:48

前端引用printJS打印

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
前端引用printJS打印

1. 引入 PrintJS

  • 下载或 CDN 引入
    • CDN 方式:在 HTML 文件的<head>标签中,通过 CDN 链接引入PrintJS的 CSS 和 JavaScript 文件。
<head> <link href="https://printjs - 4de6.kxcdn.com/print.min.css" rel="stylesheet"> <script src="https://printjs - 4de6.kxcdn.com/print.min.js"></script> </head>
  • npm 安装:如果使用构建工具(如 Webpack)管理项目,可通过 npm 安装PrintJS。在项目根目录下执行:
npm install printjs --save

安装完成后,在需要使用的模块中导入:

import printJS from 'printjs'; import 'printjs/print.min.css';

2. 准备打印内容

  • HTML 元素:在页面中定义要打印的 HTML 元素,例如一个包含报表、发票等内容的<div>元素。
<div id="print - content"> <h1>销售报表</h1> <table> <thead> <tr> <th>产品</th> <th>数量</th> <th>价格</th> </tr> </thead> <tbody> <tr> <td>产品A</td> <td>10</td> <td>$100</td> </tr> <tr> <td>产品B</td> <td>5</td> <td>$200</td> </tr> </tbody> </table> </div>
  • 图片:准备要打印的图片,可以是本地图片(通过file输入框获取)或远程图片(通过 URL 指定)。
<input type="file" id="image - input"> <img id="remote - image" src="https://example.com/image.jpg" alt="远程图片">
  • PDF 文件:如果要打印 PDF 文件,需确定 PDF 文件的 URL。
<!-- 假设PDF文件在服务器上的路径 --> <a href="https://example.com/report.pdf" target="_blank">PDF文件</a>

3. 调用 PrintJS 进行打印

  • 打印 HTML 元素:创建一个按钮或其他触发机制,在点击事件中调用printJS打印指定的 HTML 元素。
<button onclick="printHTML()">打印HTML内容</button> <script> function printHTML() { printJS({ printable: 'print - content', type: 'html', header: '销售报表', footer: '第 1 页', orientation: 'portrait', marginTop: 20, showModal: true }); } // 打印HTML元素的函数 function printHTML2() { printJS({ // 要打印的HTML元素的ID printable: 'html - to - print', // 打印类型为HTML type: 'html', // 自定义页眉内容 header: 'HTML打印示例', // 自定义页脚内容 footer: '打印时间:' + new Date().toLocaleString(), // 打印方向为纵向 orientation: 'portrait', // 上边距设置为15px marginTop: 15, // 显示打印预览模态框 showModal: true }); } // 打印图片的函数 function printImage() { printJS({ // 要打印的图片的URL,这里使用了图片元素的src属性值 printable: document.getElementById('image - to - print').src, // 打印类型为图片 type: 'image', // 图片最大宽度设置为250px maxWidth: 250, // 不扫描样式,保持图片原始样式 scanStyles: false, // 自定义页眉内容 header: '图片打印示例', // 自定义页脚内容 footer: '示例图片', // 显示打印预览模态框 showModal: true }); } </script>
  • 打印图片:为打印图片创建触发事件,根据图片来源设置printable属性。
<button onclick="printLocalImage()">打印本地图片</button> <button onclick="printRemoteImage()">打印远程图片</button> <script> function printLocalImage() { const fileInput = document.getElementById('image - input'); if (fileInput.files && fileInput.files.length > 0) { const file = fileInput.files[0]; const reader = new FileReader(); reader.onloadend = function () { printJS({ printable: reader.result, type: 'image', maxWidth: 300, scanStyles: false, header: '本地图片', showModal: true }); }; reader.readAsDataURL(file); } } function printRemoteImage() { const imageUrl = document.getElementById('remote - image').src; printJS({ printable: imageUrl, type: 'image', maxWidth: 300, scanStyles: false, header: '远程图片', showModal: true }); } </script>
  • 打印 PDF 文件:同样创建触发按钮,设置printable为 PDF 文件的 URL。
<button onclick="printPDF()">打印PDF文件</button> <script> function printPDF() { printJS({ printable: 'https://example.com/report.pdf', type: 'pdf', header: 'PDF报表', showModal: true }); } </script>

4. 处理打印相关设置

  • 样式设置:通过PrintJS的配置参数自定义打印样式。例如,设置页眉、页脚、边距、打印方向等。
printJS({ //...其他参数 header: '自定义页眉', footer: '自定义页脚', marginTop: 10, marginBottom: 10, marginLeft: 10, marginRight: 10, orientation: 'landscape' });
  • 打印预览:使用showModal参数控制是否显示打印预览模态框。设置为true时,会弹出打印预览窗口,用户可以在打印前查看效果并进行调整。
printJS({ //...其他参数 showModal: true });
  • 错误处理:虽然PrintJS相对稳定,但在实际应用中,建议添加错误处理逻辑,以处理可能出现的问题,如网络错误(在打印远程资源时)、文件读取错误(打印本地图片时)等。
try { printJS({ //...打印配置 }); } catch (error) { console.error('打印过程中出现错误:', error); // 可以在这里向用户显示友好的错误提示 }

通过以上完整流程,你可以在前端项目中灵活应用PrintJS实现各种内容的打印功能,并根据项目需求进行定制化设置。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/20 11:25:48

python的iloc用法

口诀 .iloc[行位置, 列位置] 只看整数下标&#xff0c;从左到右从 0 开始数 练习 1.调试打印前 8 行&#xff08;只看前 10 列&#xff09; for i in range(8):print(df_raw.iloc[i, :10].tolist())写法含义df.iloc[r, c]单个标量df.iloc[r1:r2, c1:c2]连续块&#xff08;切片&…

作者头像 李华
网站建设 2026/4/17 8:40:45

sci文献检索入口使用指南:快速获取权威学术资源的实用方法

① WisPaper&#xff08;文献聚类 术语辅助&#xff09; 官网&#xff1a;https://www.wispaper.ai 帮助快速理解陌生领域的核心概念和研究主题。 ② Elicit 自动列出最相关论文和方法&#xff0c;为跨学科快速扫文献提供便利。 ③ Explainpaper 逐段解释论文内容&#xff0c…

作者头像 李华
网站建设 2026/4/17 9:15:18

学术搜索入口:便捷高效的学术资源检索平台与工具指南

① WisPaper&#xff08;文献聚类 术语辅助&#xff09; 官网&#xff1a;https://www.wispaper.ai 帮助快速理解陌生领域的核心概念和研究主题。 ② Elicit 自动列出最相关论文和方法&#xff0c;为跨学科快速扫文献提供便利。 ③ Explainpaper 逐段解释论文内容&#xff0c…

作者头像 李华
网站建设 2026/4/12 21:50:15

分享提示工程师课程培训:掌握与AI对话的核心法则

在人工智能飞速发展的今天&#xff0c;一项被誉为“与机器对话的艺术”的核心技能——提示工程&#xff0c;正成为推动AI应用落地的关键引擎。你是否还在为职业发展方向犹豫不决&#xff1f;是否在寻找一个想创造价值的新赛道&#xff1f;获得一张专业的提示工程师证书&#xf…

作者头像 李华
网站建设 2026/4/16 18:11:53

退休规划计算器:基于工资数据的科学退休时间预测工具

在人口老龄化与养老保障体系日益受到关注的背景下&#xff0c;如何科学规划退休时间成为职场人士的重要课题。本网站通过整合工资数据、社保政策与精算理论&#xff0c;为用户提供个性化的退休时间预测服务&#xff0c;助力理性规划职业生涯。 一、网站核心功能 多维度数据输入…

作者头像 李华