当前位置: 首页 > news >正文

最简单的 Web 打印方案:用 5 分钟上手 web-print-pdf(npm 包) - 实践

最简单的 Web 打印方案:用 5 分钟上手 web-print-pdf(npm 包) - 实践

这篇文章给出一条“开箱即用、稳定、跨浏览器”的 Web 打印最简路线:使用 web-print-pdf(npm 包)。不需要安装浏览器插件、无需控件注册表操作,也不用学习繁琐的打印脚本,只需几行代码即可把 HTML、PDF、图片精准送到打印机。

为什么选择 web-print-pdf

  • 简单:API 极简,常见打印需求(PDF/HTML/图片、静默打印、批量打印)一步到位。
  • 可靠:通过本地服务与 Electron/无头内核协作,规避浏览器安全限制与差异。
  • 可控:纸张大小、方向、边距、份数、目标打印机、队列、并发都可配置。
  • 可移植:前端 npm 生态集成方便,后端、桌面端、混合架构都能无缝接入。

相比传统方案:

  • 和 Lodop 一类控件相比:无需控件安装、证书、浏览器兼容适配,前端接入更轻量。
  • 和纯浏览器方案相比:无需依赖用户交互弹窗或浏览器实验开关,静默打印更稳定。
  • 和重型可视化模板库相比:更聚焦“把已生成的内容稳妥印出”,学习成本更低。

5 分钟快速上手

1)安装
npm i web-print-pdf

确保运行时已部署本地打印服务(项目提供 Electron 打包与一键安装能力);前端仅调用 API 即可。

2)打印 PDF(最常见场景)
import { printPdfByUrl
} from 'web-print-pdf';
async function quickPrint() {
await printPdfByUrl({
url: 'https://example.com/order.pdf',
printer: 'HP-LaserJet',
copies: 1,
duplex: false,
paper: 'A4',
silent: true,
});
}
3)打印 HTML(自动生成或远程页面)
import { printHtmlByUrl, printHtmlByBase64
} from 'web-print-pdf';
// 远程 URL
await printHtmlByUrl({
url: 'https://example.com/preview.html', silent: true
});
// Base64 字符串(适合前端动态生成的 DOM + 样式)
await printHtmlByBase64({
base64: btoa('<html>...</html>'), silent: true
});
4)打印图片
import { printImageByUrl, printImageByBase64
} from 'web-print-pdf';
await printImageByUrl({
url: 'https://example.com/ticket.png', silent: true
});

典型业务场景

  • 电商/仓配:批量面单、拣货单、出库单静默打印;支持队列与并发控制,防止卡顿。
  • 连锁零售:小票、价签、标签快速打印,指定门店默认打印机自动落盘。
  • 医院/政务:表单、回执、凭证批量打印;纸张与边距严格可控,满足合规要求。
  • 制造/物流:工艺卡/条码标签打印;支持图片、PDF 混合任务一并下发。

配置项一览(常用)

小贴士:实际可用参数会因驱动与机型差异有所不同,建议先通过打印机列表与纸型查询接口进行校验。

和其它方案的对比

  • 对比 Lodop:无需安装与授权,API 与前端生态更友好;同时保留纸型与静默能力。
  • 对比 hiprint:后者偏重可视化模板设计,适合“模板搭建”;web-print-pdf 则专注“把内容稳定印出”,二者可互补。
  • 对比浏览器原生 window.print:无需用户点击、可静默、可选打印机、可批量、可并发。

最佳实践

常见问题

Q:支持哪些浏览器? 只要能调用前端接口即可,核心能力由本地服务/Electron 内核承担,规避浏览器差异。

Q:如何静默打印? 设置 silent: true,以及在部署时开启本地服务对应权限配置即可。

Q:如何指定纸张和边距? 通过 papermarginorientation 等参数,并结合打印机驱动能力。

Q:能否批量任务并发? 内置队列与并发控制,避免阻塞;也可按业务维度分组串行。

结语

如果你的目标是“最短时间把内容稳定打印出来”,web-print-pdf(npm 包)就是当前最简单、最有效的路径:

现在就为你的项目加入可靠的打印能力吧。

http://www.hskmm.com/?act=detail&tid=27891

相关文章:

  • 2025 年塑木厂家最新推荐:实力厂家排行榜 —— 含围栏地板栈道等产品企业技术服务优势解析塑木地板/栈道/护栏/门板/凉亭/墙板/托盘厂家推荐
  • 如何将GIS属性一键快速标注到AutoCAD图纸上?
  • 坯子插件库 v3.2.1 for SketchUp 2022-2024下载与安装教程
  • 免费绿色版识别软件,OCR识别软件!最全安装使用教程(附下载地址)
  • 2025年超微粉碎机优质实力厂家推荐,产品涵盖低温无尘粉碎机/液氮冷冻/万能/锤式粉碎机!
  • linux常用操作 - 吾辈当奋斗
  • 2025 年高低温试验箱制造厂家最新推荐排行榜:精选优质品牌,助力企业精准选购可靠测试设备恒温恒湿试验箱/高低温试验箱厂家推荐
  • MySQL数据库入门指南,5分钟掌握连接与基础操作命令
  • zookeeper常用操作 - 吾辈当奋斗
  • 基于旋转不变子空间(ESPRIT)算法的DOA估计
  • 一堆todo - 吾辈当奋斗
  • 大规模图神经网络高效训练新方法
  • 10 10
  • cocos3节点监听不到TOUCH_START问题
  • Rudin 数学分析第二章
  • Gitee DevOps平台:中国企业数字化转型的加速器
  • aardio在其他窗体调用主窗体的函数
  • 全社会是否真的需要一套AI元人文实践框架?
  • 2025人工智能在无人机数据处理中的应用
  • 基于自适应观测器的无传感器感应电动机矢量控制仿真
  • 高性能场景为什么推荐使用PostgreSQL,而非MySQL?
  • 【EI期刊、EI-JA检索】第五届新能源与电力工程国际学术会议(ICNEPE 2025)
  • 告别普通游客照:在线P图让你的社交媒体脱颖而出
  • STC单片机用户程序控制ISP下载
  • 国产DevOps工具链崛起:Gitee如何助力企业数字化转型破局
  • SAP移动类型TR和TF和TP
  • docker-compose 启动 elk
  • Gitee领航中国DevOps市场:本土化优势与云原生战略的双轮驱动
  • 禅道怎么更新MySQL数据库的用户名和密码
  • 【IEEE出版、EI检索稳定】 第五届数字化社会与智能系统国际学术会议(DSInS 2025)