想象一下您收到一项任务:在一周内创建一个新的文档网站。它应该具有视觉吸引力、快速且易于导航。您会收到一堆 *.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中文网其他相关文章!

Python和JavaScript的主要区别在于类型系统和应用场景。1.Python使用动态类型,适合科学计算和数据分析。2.JavaScript采用弱类型,广泛用于前端和全栈开发。两者在异步编程和性能优化上各有优势,选择时应根据项目需求决定。

选择Python还是JavaScript取决于项目类型:1)数据科学和自动化任务选择Python;2)前端和全栈开发选择JavaScript。Python因其在数据处理和自动化方面的强大库而备受青睐,而JavaScript则因其在网页交互和全栈开发中的优势而不可或缺。

Python和JavaScript各有优势,选择取决于项目需求和个人偏好。1.Python易学,语法简洁,适用于数据科学和后端开发,但执行速度较慢。2.JavaScript在前端开发中无处不在,异步编程能力强,Node.js使其适用于全栈开发,但语法可能复杂且易出错。

javascriptisnotbuiltoncorc; saninterpretedlanguagethatrunsonenginesoftenwritteninc.1)javascriptwasdesignedAsalightweight,解释edganguageforwebbrowsers.2)Enginesevolvedfromsimpleterterterpretpreterterterpretertestojitcompilerers,典型地提示。

JavaScript可用于前端和后端开发。前端通过DOM操作增强用户体验,后端通过Node.js处理服务器任务。1.前端示例:改变网页文本内容。2.后端示例:创建Node.js服务器。

选择Python还是JavaScript应基于职业发展、学习曲线和生态系统:1)职业发展:Python适合数据科学和后端开发,JavaScript适合前端和全栈开发。2)学习曲线:Python语法简洁,适合初学者;JavaScript语法灵活。3)生态系统:Python有丰富的科学计算库,JavaScript有强大的前端框架。

JavaScript框架的强大之处在于简化开发、提升用户体验和应用性能。选择框架时应考虑:1.项目规模和复杂度,2.团队经验,3.生态系统和社区支持。

引言我知道你可能会觉得奇怪,JavaScript、C 和浏览器之间到底有什么关系?它们之间看似毫无关联,但实际上,它们在现代网络开发中扮演着非常重要的角色。今天我们就来深入探讨一下这三者之间的紧密联系。通过这篇文章,你将了解到JavaScript如何在浏览器中运行,C 在浏览器引擎中的作用,以及它们如何共同推动网页的渲染和交互。JavaScript与浏览器的关系我们都知道,JavaScript是前端开发的核心语言,它直接在浏览器中运行,让网页变得生动有趣。你是否曾经想过,为什么JavaScr


热AI工具

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

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

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

Atom编辑器mac版下载
最流行的的开源编辑器

适用于 Eclipse 的 SAP NetWeaver 服务器适配器
将Eclipse与SAP NetWeaver应用服务器集成。

PhpStorm Mac 版本
最新(2018.2.1 )专业的PHP集成开发工具

SublimeText3汉化版
中文版,非常好用

SublimeText3 Linux新版
SublimeText3 Linux最新版