最主流的JavaScript生成PDF方案有三种:前端轻量导出用jsPDF配合html2canvas,结构化文档推荐pdfmake,高还原度服务端渲染选Puppeteer。

用 JavaScript 生成 PDF,主流方式是前端直接生成(适合简单报表、导出页面片段)或调用后端服务(适合复杂排版、敏感数据、大量数据)。目前最成熟、轻量且纯前端的方案是 jsPDF,配合 html2canvas 可实现“网页截图转 PDF”;若需更精准的 HTML → PDF 渲染(比如保留 CSS 样式、分页、字体嵌入),推荐 pdfmake 或服务端方案如 Puppeteer(Node.js 环境)。
jsPDF:基础 PDF 创建 + 手动绘图
适合生成结构简单、内容可控的 PDF,比如发票、证书、纯文本报告。它不解析 HTML,而是提供类似 Canvas 的 API(addText、rect、line、addImage 等)手动构建页面。
- 优点:体积小(约 150KB)、无依赖、兼容性好、可完全离线运行
- 缺点:写布局代码繁琐,不支持自动换行、CSS、HTML 元素直接转换
- 小技巧:用 autoTable 插件可快速绘制带样式的表格;用 addImage 结合 html2canvas 截图 DOM 后插入图片,绕过排版限制
pdfmake:声明式 HTML/CSS 风格生成 PDF
通过 JSON 描述文档结构(text、stack、table、columns 等),内置简单样式系统和分页逻辑,比 jsPDF 更贴近“写文档”的直觉。
- 优点:语义清晰、支持中文字体(需手动注册 ttf)、自动分页、表格/列表原生支持
- 缺点:学习成本略高;复杂 CSS(如 flex、grid)不支持;中文需额外配置字体文件
- 典型流程:准备中文 TTF 字体 → 在 pdfMake.fonts 中注册 → 使用 fonts 属性指定字体 → 生成 docDefinition → pdfMake.createPdf(docDefinition).download()
Puppeteer(Node.js):服务端高质量 HTML → PDF
如果你有 Node.js 后端,Puppeteer 是目前最接近浏览器打印效果的方案。它启动 Chromium 实例,加载 HTML 页面,再调用 page.pdf() 输出 PDF。
标签: css react javascript java html js 前端 node.js json node svg s
还木有评论哦,快来抢沙发吧~