使用JavaScript生成PDF文件_javascript文件操作

使用jspdf库可在前端生成PDF文件,首先通过cdnnpm引入库,创建jsPDF实例后可添加文本、图片、表格等内容,并支持自定义页面尺寸、方向及导出控制,结合autoTable插件能生成复杂表格,最终可保存为文件或获取Blob对象用于预览上传。

使用JavaScript生成PDF文件_javascript文件操作

在网页开发中,有时需要在前端直接生成 PDF 文件,比如导出报表、简历或合同。javaScript 可以通过一些库来实现这一功能,无需依赖后端。下面介绍如何使用 jsPDF 这个流行的库来生成 PDF 文件,并进行基本的文件操作。

引入 jsPDF 库

jsPDF 是一个轻量级的 javascript 库,可以在浏览器中生成 PDF。你可以通过 CDN 引入,也可以使用 npm 安装。

CDN 方式:

<script src="https://cdnjs.cloudflare.com/ajax/libs/jspdf/2.5.1/jspdf.umd.min.js"></script>

npm 安装:

<pre class="brush:php;toolbar:false;">npm install jspdf

创建一个简单的 PDF 文件

引入库之后,就可以用几行代码生成一个基础 PDF。

const { jsPDF } = window.jspdf;  // 创建一个新的 PDF 实例 const doc = new jsPDF();  // 添加文本 doc.setFontSize(16); doc.text("Hello, 世界!", 10, 10);  // 保存文件 doc.save("example.pdf"); 

这段代码会生成一个包含“Hello, 世界!”文本的 PDF 文件,并自动下载为 example.pdf

立即学习Java免费学习笔记(深入)”;

添加更多内容(图片、表格等)

jsPDF 支持添加图像、表格、设置字体和样式等高级功能。

插入图片示例:

// 假设你有一张 base64 编码的图片 const imgData = '...'; // 省略具体 base64  doc.addImage(imgData, 'JPEG', 10, 20, 50, 50); // x, y, width, height doc.save('with-image.pdf'); 

使用插件生成表格(需引入 autoTable):

doc.autoTable({   head: [['Name', 'Email']],   body: [     ['Alice', 'alice@example.com'],     ['Bob', 'bob@example.com']   ] });  doc.save('table.pdf'); 

记得引入 autoTable 插件:

<script src="https://cdnjs.cloudflare.com/ajax/libs/jspdf-autotable/3.5.23/jspdf.plugin.autotable.min.js"></script>

前端文件操作与导出控制

除了生成 PDF,你还可以对文件名、格式、页面方向等进行控制。

  • 横向页面:new jsPDF(‘landscape’)
  • A5 尺寸:new jsPDF(‘p’, ‘mm’, ‘a5’)
  • 不自动下载:使用 doc.output('blob') 获取 Blob 对象,便于上传或预览

获取 Blob 示例:

const pdfBlob = doc.output('blob'); const file = new File([pdfBlob], "report.pdf", { type: "application/pdf" }); // 可用于上传到服务器 

基本上就这些。使用 jsPDF 能满足大多数前端生成 PDF 的需求,操作简单,兼容性好。结合用户输入动态生成内容,非常适合做导出功能。注意内容过多时分页处理,避免文字溢出。基本上按结构一步步添加内容即可。

以上就是使用JavaScript生成PDF文件_

上一篇
下一篇
text=ZqhQzanResources