从HTML创建PDF

从html创建pdf:一种无需php库的简易方法

许多开发者使用PHP库(如tcpdf)从HTML生成PDF,但这些库代码复杂,修改困难且效率低下。本文介绍一种更简洁的方法,利用JavaScript库jspdf和jspdf-autotable直接从HTML元素生成PDF,再通过PHP文件发送邮件,无需任何PHP PDF库。

从HTML创建PDF

步骤1:准备HTML内容

首先,创建包含所需内容的HTML代码。例如:

立即学习“前端免费学习笔记(深入)”;

关键雇佣条款

所有字段均为必填项,除非不适用

签发日期:

所有信息均以签发日期为准

步骤2:设置打印样式 (CSS)

使用CSS控制打印内容的格式。以下CSS代码只在打印模式下生效:

@media print {    body * { visibility: hidden; }    body { counter-reset: page; }    #printarea, #printarea * { visibility: visible; }    #printarea { position: absolute; left: 0; top: 0; }    .btnadd, button { display: none !important; }}

此CSS隐藏页面所有内容,只显示#printarea div。

步骤3:JavaScript打印页面

点击“打印”按钮时,JavaScript触发打印功能并动态设置PDF文件名:

function printdiv() {    const employeename = 'somename'; // 使用动态名称替换    document.title = `${employeename}.pdf`;    window.print();}

浏览器将提示打印或保存为PDF。

步骤4:使用jspdf生成PDF

为了程序化生成PDF并发送邮件,使用jspdf库。

步骤5:处理非拉丁字符和表格

为了支持非拉丁字符,需要预加载字体。将TTF字体(如droidsansfallback.ttf)转换为base64编码,并将其包含在PDF生成过程中。以下代码演示了如何加载字体并生成包含表格和非拉丁字符的PDF:

async function generateAndSendPDF() {    const doc = new window.jspdf.jsPDF();    const employeeName = 'SomeName';    const filename = `${employeeName}.pdf`;    const base64Font = await loadFontOnce(); // 加载字体函数 (见下文)    doc.addFileToVFS("DroidSansFallback.ttf", base64Font);    doc.addFont("DroidSansFallback.ttf", "DroidSansFallback", "normal");    doc.setFont("DroidSansFallback");    doc.text("员工信息1русский1书、杂志等中区别于图片的)正文,文字材料", 10, 10);    // ... 添加其他内容 ...    doc.autoTable({        // ... 表格配置 ...    });    const pdfBase64 = doc.output("datauristring").split(',')[1];    // 使用AJAX发送PDF到PHP文件    fetch("filename.php", {        // ... 发送请求 ...    });    window.open(doc.output("bloburl"), "_blank");}async function loadFontOnce() {    // ... 加载base64字体的函数 ...}

filename.php文件中,添加发送邮件的代码。

结论

此方法使用JavaScript直接从HTML生成PDF,无需外部PHP库,支持表格和非拉丁字符,灵活且高效。生成的PDF可通过PHP文件发送邮件。

不足之处:

需要为每个HTML编写JavaScript代码。需要包含较大的base64编码字体文件。

希望此方法能帮助您简化PDF生成流程!

以上就是从HTML创建PDF的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1501499.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月19日 23:36:47
下一篇 2025年12月14日 13:25:40

相关推荐

  • 顶级React JS访谈问题

    精通React框架的关键概念和原则对每位React开发者至关重要。本文总结了十个核心问题,涵盖了React开发的各个方面,无论您是准备面试还是提升技能,都将受益匪浅。建议您在查看答案前尝试独立作答,这将帮助您更好地评估自身掌握程度并发现需要改进的领域。 一、什么是React及其优势? React是一…

    2025年12月19日
    000
  • 在实践中反应:用钩子改善形式

    使用表格 一个常见的情况是处理表格的逻辑,可以为自定义钩提取 // form.tsximport { formeventhandler, usestate } from “react”;function forms() { const [title, settitle] = usestate(“”)…

    好文分享 2025年12月19日
    000
  • 如何将shadcn与react使用(javaScript,无打字稿)

    使用vite和tailwind css 3.4.1构建react项目并集成shadcn ui组件 本文档指导您如何在不使用TypeScript的情况下,使用Vite构建一个React项目,并集成shadcn UI组件库。我们将使用Tailwind CSS 3.4.1版本,因为它与shadcn当前版本…

    2025年12月19日
    000
  • 为什么在网站中选择seo的nextJ?

    Next.js:提升网站SEO的利器 在当今竞争激烈的网络环境中,拥有一个易于搜索引擎发现的网站至关重要。SEO(搜索引擎优化)是关键,而Next.js正成为许多开发者的首选框架。如果您是自由职业的Web开发者,React开发者,或正计划雇佣自由职业者进行网站开发,那么了解Next.js对SEO的益…

    2025年12月19日
    000
  • 与NextJS集成的Redsys介绍15

    如今,众多企业寻求在线盈利途径,例如SaaS、电商或其他网络应用。虽然Stripe和PayPal等全球支付平台普及,但不同国家/地区偏好各有不同。在西班牙,Redsys几乎主导所有在线银行交易。Redsys是一个基于SOAP API的平台,旨在简化和保障西班牙银行网络的数字支付。尽管功能强大,但其独…

    2025年12月19日
    000
  • 在不到两分钟的时间内旋转新铁路上的许可证密钥API!

    Railway 的新功能特性让部署单文件微服务变得轻而易举,无需管理基础设施或代码库。本文将演示如何使用 Hono、Redis 和 Bun 运行时,在一个文件中构建一个许可证 API。准备开始构建吧! 注意: Railway 功能非常适合处理小型任务,例如网络钩子、cron 作业或简单的 API。它…

    2025年12月19日
    000
  • 您是在犯这些Nodejs安全错误吗?

    介绍 >在2016年,当黑客通过利用私人github存储库中的暴露凭据访问其aws s3服务器时,uber面临严重的安全漏洞。该服务器包含5700万用户和60万驱动程序的敏感数据。违规发生是由于不良的访问控制和凭证管理在其node.js应用程序中。如果像uber这样的技术巨头可能会发生这种情况…

    好文分享 2025年12月19日
    000
  • 掌握get和在API中发布:路由参数与查询参数

    理解GET和POST请求以及如何有效运用查询参数(req.query)和路由参数(req.params)是构建健壮API的关键。 GET请求 GET请求用于从服务器获取数据,类似于提出问题,不会修改服务器状态。 // 客户端请求:fetch(‘https://api.example.com/user…

    2025年12月19日
    000
  • 在摩尔多瓦创建网站:成功的关键步骤

    在摩尔多瓦建立网站是企业、自由职业者和创业者拓展在线业务的关键一步。无论您需要的是个人博客、电商平台还是公司官网,都需要遵循以下几个重要步骤: 域名和主机选择: 首先,选择一个能够体现您品牌形象的域名。摩尔多瓦常用的域名后缀包括 .md 和 .com。 接下来,选择一个速度快、稳定性高的可靠主机服务…

    2025年12月19日
    000
  • 如何修复“无’访问控制 – 允许孔”标题”错误

    您可能遇到过令人头疼的“无访问控制-允许来源”错误。本文将提供多种解决方案,助您轻松修复此网络开发常见问题。 CORS错误 理解“无访问控制-允许来源”错误 此错误主要分为两种情况: 缺少Access-Control-Allow-Origin CORS头信息:浏览器无法验证是否允许跨域请求。Acce…

    2025年12月19日
    000
  • 承诺解决了

    在将Promise集成到工作流程时,并非所有函数都需要是Promise,关键在于保持Promise链的完整性。 谨记:勿断链 正如Fleetwood Mac所唱,“永远不要打破链条”。 在异步工作流程中,避免从外部访问异步操作的结果是至关重要的。无论是Promise、async/await还是事件监…

    2025年12月19日
    000
  • 双向将信号输入对象值绑定为[(ngmodel)]

    最近,我遇到了这一挑战…重构形式成分的角度信号。 旧形式组件的工作原理: > 表单数据来自反应性状态服务>表单数据是对象>在将其传递给form component>之前,将其形式数据克隆到克隆之前表单组件通过一个基于经典的装饰 angular @input 接收表…

    2025年12月19日
    000
  • 掌握Rollupjs:从基础到高级

    Rollup.js入门指南:高效的ES模块打包工具 Rollup.js 是一款轻量级的 JavaScript 模块打包器,尤其擅长处理 ES 模块。与Webpack等重量级打包器相比,它配置简单,学习成本低,生成的代码更简洁高效。本文将介绍 Rollup.js 的基本用法,并说明其优势。 一、为什么…

    2025年12月19日
    000
  • 使用我们的业务电子邮件数据库与德国的主要决策者联系

    德国是欧洲经济强国,对寻求拓展业务的企业而言至关重要。ready mailing团队提供的德国企业邮箱数据库,让您的企业能够接触到来自it、金融、医疗、零售等多个行业的数千个已验证联系人。这个全面且符合gdpr的数据库,旨在帮助您精准定位目标受众,与决策者建立联系,从而加速德国市场的业务增长。 什么…

    2025年12月19日
    000
  • 为您的React应用程序选择正确的CSS方法

    React应用的样式化方法多种多样,选择哪种方法取决于个人喜好、项目需求和团队协作。以下列举了五种常见的React应用CSS方法。 1. 标准CSS 在独立的.css文件中编写CSS代码,然后导入到React组件中。 /* styles.css */.button { background-colo…

    2025年12月19日
    000
  • 反应性组件热加载与状态保存

    现代网络开发追求快速、流畅的用户体验。然而,传统的全页刷新机制在应用代码更改时会清除用户输入、身份验证数据和导航历史,迫使开发者每次更新后都重新搭建测试环境。热重载技术应运而生,它在保持应用状态的同时实时更新代码,显著提升了开发效率。 热重载允许开发者实时查看UI更改并进行测试,无需重置应用。Rea…

    2025年12月19日
    000
  • 医生旅程:恢复在线交易中损失的资金

    我叫Patrick Bonneau,在洛杉矶行医已有15年。我对比特币和其他加密货币平台并不了解,因此不幸掉入了一个在线交易骗局,损失近150万美元。起初,该平台看起来很正规,有专业的视频和诱人的收益截图。投资后,初期一切顺利,骗子还会定期更新信息。但很快,平台就失联了,我无法访问账户或提取资金,身…

    2025年12月19日
    000
  • JS中的简单内存数据库

    大家好! 我最近完成了一个很有趣的项目:一个基于JavaScript的简易内存数据库。这个项目的目标是提升我对对象回收机制的理解,并深入学习数据库底层运作原理。 我特别想实现一种直观的查询功能,能够进行数据过滤操作,这在很多项目中都非常实用。 我的设计灵感来源于Prisma ORM,力求打造一个简洁…

    2025年12月19日
    000
  • JavaScript对象魔术

    本文探讨JavaScript对象赋值的特性及其潜在问题,并提供解决方案。 对象赋值与引用: 以下代码片段演示了JavaScript对象赋值的机制: const person = { firstname: ‘ajay’, lastname: ‘kumar’, hobbies: [‘cricket’, …

    2025年12月19日
    000
  • 第三方图书馆的隐藏成本:当&#don&#t重新发明车轮&#错误

    程序员奉为圭臬的信条之一是“不要重复造轮子”。然而,如同软件开发中的许多绝对性断言一样,实际情况远比这复杂。本文将探讨引入看似便捷的npm包时,其成本可能远高于自行编写代码的情况。 免费代码的陷阱 我们都经历过:需要实现某个功能,恰好有一个npm包能完美胜任。它很流行,维护良好,只需npm inst…

    2025年12月19日
    000

发表回复

登录后才能评论
关注微信