想象一下您收到一项任务:在一周内创建一个新的文档网站。它应该具有视觉吸引力、快速且易于导航。您会收到一堆 *.docs 文件、图像和屏幕截图,以及“完成它”.
的说明有很多优秀的工具可供选择,例如Docusaurus、Nextra、VitePress、Docus等等。之前,我在使用 Starlight 构建文档网站方面获得了丰富的经验,因此我选择了它来完成这项任务。然而,我发现了一个缺失的功能:从文档生成 PDF 的能力。这是要求之一。 “听起来像是一个不错的副业项目,”我自己想的。
解决任务
起初,这似乎很简单:获取页面,解析 HTML,对内容进行分组,瞧!
星光驱动的网站有一个“下一步”按钮来浏览文档。由于 PDF 本质上是页面数组,因此使用“下一步”按钮逐一解析它们似乎是合乎逻辑的。由于网站生成静态页面,我很快编写了一个脚本来获取 HTML、查询必要的部分,并将所有内容组合在一起。然而,事实证明,生成保留网站样式的 PDF 更为复杂。经过一番头脑风暴,我意识到 Puppeteer 是最好的解决方案。
现在流程变得清晰了:
- 确定起始页面。这是带有“下一步”按钮的第一页。
- 浏览页面。从每个页面提取标题和主要内容,同时构建目录。
- 合并内容。添加分页符和其他样式。
- 准备最终的 HTML。 重写 包含生成的 HTML 的初始页面。
- 加载资源。滚动页面至底部加载所有图片。
- 生成 PDF。Puppeteer 的 Page.pdf() 方法可以解决这个问题。
- 完成!
这就是starlight-to-pdf 的工作原理。遵循这种模式,您可以为缺乏 PDF 导出功能的其他文档框架构建类似的工具。
后续步骤
基本功能准备就绪后,就该添加一些额外功能了。以下是最有趣和最具挑战性的功能。
添加页眉和页脚
页眉或页脚中包含页码和一些附加信息是很好的。 Puppeteer 的 Page.pdf() 方法接受 headerTemplate 和 footerTemplate 选项。这些选项接受 HTML 字符串。 Puppeteer 自动将值注入到具有特定实用程序类的元素中:
- .date:格式化日期;
- .title:网页的标签值;
- .url: 调用打印函数的页面 URL;
- .pageNumber:当前页码;
- .totalPages: 文档的总页数。
当我们在打印之前将所有内容合并在一页上时,标题和网址对我们来说没有太大价值:插入的值将始终保持不变。然而,其他课程有很大帮助。这是页脚模板示例:
<style> .footer-container { --color: #000; display: flex; align-items: center; justify-content: space-between; border-block-start: 1px solid var(--color); color: var(--color); font-size: 10px; font-family: Arial, Helvetica, sans-serif; margin-inline: 1.5cm 1cm; padding-block: 0.25cm 0.5cm; width: 100%; } </style> <div> <p>To use this, do not forget to set the displayHeaderFooter property to true:<br> </p> <pre class="brush:php;toolbar:false">import puppeteer from 'puppeteer'; const browser = await puppeteer.launch(); const page = await browser.newPage(); await page.goto('https://someUrl'); const footerTemplateStr = '<style>...<style><div>...</style>
以下是您应该牢记的一些发现:
- 模板必须是有效的 HTML 结构。
- 定义 font-size CSS 属性,Puppeteer 的默认值为 0。
- 使用内联
- 图像应编码为 base64 字符串。
- 使用 Puppeteer 的边距选项来实现所需的布局。
CLI 样式怎么样?
一切正常,生成的 PDF 看起来很棒,但终端消息感觉平淡无奇。对细节的关注将好与伟大区分开来,不是吗?让我们的消息更加丰富多彩、更易于阅读。
这就是 ANSI 转义序列的魔力。我认为 4 位颜色足以完成这项工作。假设您想要红色背景上的白色文本(这就是我用于[错误]:错误消息之前的前缀)。以下是实现这种外观的方法:
console.log('\x1b[37;41m', 'White on red message');
让我们来分解一下:
- x1b[ 是十六进制转义码(您也可以使用 u001b 作为 Unicode 替代);
- 37 是前景色白色,其中 3 代表前景色,7 代表白色;
- 41 是背景红色,其中 4 代表背景,1 代表红色。
一切正常,但现在我们所有的 console.log() 输出都将以这种方式设置样式。要将样式重置回默认值,只需在末尾添加重置序列 x1b[0m:
console.log('\x1b[37;41m', 'White on red message', '\x1b[0m');
好多了。如果我们想要在灰色背景上显示粗体青色文本(4 位颜色名称中的亮黑色),该怎么办?很简单:
console.log('\x1b[1;36;100m', 'Cyan on gray message in bold', '\x1b[0m');
以下是每个部分的作用:
- 1 转义码后应用粗体效果;
- 36 设置文本颜色为青色;
- 100 将背景更改为亮黑色,其中 10 表示明亮,0 是黑色的代码。
利用这些知识,您可以使您的 CLI 工具在视觉上更具吸引力。例如,我在项目中将所有 URL 和文件路径设置为带下划线的蓝色文本:
console.log('\x1b[4;34m', './underlined/blue', '\x1b[0m')
查看此备忘单以了解有关该主题的更多信息。
总结
你永远不知道什么时候日常任务可能会激发出有益的副业项目。 starlight-to-pdf 的开发为 Puppeteer 和 CLI 样式提供了宝贵的经验,并且开源社区中出现了一种新工具。这是一个快速演示:
以上是将 Starlight 转换为 PDF:经验和见解的详细内容。更多信息请关注PHP中文网其他相关文章!

JavaScript字符串替换方法详解及常见问题解答 本文将探讨两种在JavaScript中替换字符串字符的方法:在JavaScript代码内部替换和在网页HTML内部替换。 在JavaScript代码内部替换字符串 最直接的方法是使用replace()方法: str = str.replace("find","replace"); 该方法仅替换第一个匹配项。要替换所有匹配项,需使用正则表达式并添加全局标志g: str = str.replace(/fi

本教程向您展示了如何将自定义的Google搜索API集成到您的博客或网站中,提供了比标准WordPress主题搜索功能更精致的搜索体验。 令人惊讶的是简单!您将能够将搜索限制为Y

因此,在这里,您准备好了解所有称为Ajax的东西。但是,到底是什么? AJAX一词是指用于创建动态,交互式Web内容的一系列宽松的技术。 Ajax一词,最初由Jesse J创造

本文系列在2017年中期进行了最新信息和新示例。 在此JSON示例中,我们将研究如何使用JSON格式将简单值存储在文件中。 使用键值对符号,我们可以存储任何类型的

利用轻松的网页布局:8个基本插件 jQuery大大简化了网页布局。 本文重点介绍了简化该过程的八个功能强大的JQuery插件,对于手动网站创建特别有用

核心要点 JavaScript 中的 this 通常指代“拥有”该方法的对象,但具体取决于函数的调用方式。 没有当前对象时,this 指代全局对象。在 Web 浏览器中,它由 window 表示。 调用函数时,this 保持全局对象;但调用对象构造函数或其任何方法时,this 指代对象的实例。 可以使用 call()、apply() 和 bind() 等方法更改 this 的上下文。这些方法使用给定的 this 值和参数调用函数。 JavaScript 是一门优秀的编程语言。几年前,这句话可

jQuery是一个很棒的JavaScript框架。但是,与任何图书馆一样,有时有必要在引擎盖下发现发生了什么。也许是因为您正在追踪一个错误,或者只是对jQuery如何实现特定UI感到好奇

该帖子编写了有用的作弊表,参考指南,快速食谱以及用于Android,BlackBerry和iPhone应用程序开发的代码片段。 没有开发人员应该没有他们! 触摸手势参考指南(PDF) Desig的宝贵资源


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

mPDF
mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

安全考试浏览器
Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。

MinGW - 适用于 Windows 的极简 GNU
这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3 Linux新版
SublimeText3 Linux最新版