0

0

html2canvas导出pdf 网页截图怎么生成pdf【转换】

蓮花仙者

蓮花仙者

发布时间:2026-03-05 17:49:41

|

823人浏览过

|

来源于php中文网

原创

html2canvas 仅生成 canvas 图片,导出 pdf 必须结合 jspdf 的 addimage();需设 scale: 2、手动适配 a4 像素尺寸(794×1123)、确保中文字体可用、usecors: true + allowtaint: false 解决跨域与截全问题。

html2canvas导出pdf 网页截图怎么生成pdf【转换】

html2canvas 本身不生成 PDF,得靠 jsPDF 中转

html2canvas 只负责把网页元素画成 Canvas 图片,它没有 PDF 生成功能。想导出 PDF,必须把 canvas 输出的 data URLblob 交给 jsPDFaddImage() 方法拼成 PDF 页面。

常见错误是直接调用 html2canvas().then(canvas => canvas.toBlob(...)) 就以为完事了——结果只拿到一张 PNG,根本不是 PDF。

  • 必须引入 jsPDF(推荐用 jspdf@2.5.1+,老版本对高 DPI 屏幕支持差)
  • html2canvasscale 建议设为 2,否则在 Retina 屏上截图模糊
  • 如果页面内容超一页,jsPDF 不会自动分页——得手动切区域、多次 addImage()

导出 A4 尺寸 PDF 时,canvas 宽高要按 96dpi 换算

浏览器里 1cm ≈ 37.8px(按 96dpi 计算),A4 纸是 210mm × 297mm → 换算成像素约 794px × 1123px。但 html2canvas 默认按元素原始尺寸渲染,不考虑打印尺寸,所以得手动控制 canvas 输出大小。

否则 PDF 看起来“太小”或“被压缩”,尤其文字边缘发虚。

Axiom
Axiom

Axiom是一个浏览器扩展,用于自动化重复任务和web抓取。

下载

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

  • html2canvas{ width: 794, height: 1123, scale: 2 },确保输出 canvas 至少 1588×2246 像素
  • 创建 jsPDF 实例时用 new jsPDF({ unit: 'px', format: [794, 1123] }),单位和尺寸对齐
  • 调用 addImage() 时指定宽高: pdf.addImage(imgData, 'PNG', 0, 0, 794, 1123)

中文乱码?字体没嵌入,不是编码问题

jsPDF 默认只支持 ASCII 字体,哪怕页面用了 @font-face 引入思源黑体,导出 PDF 后中文仍显示为方块——因为 addImage() 是把 canvas 当图片贴进去,字体渲染已在 canvas 阶段完成;而 canvas 绘制中文依赖系统字体,若目标环境(比如 Linux 服务器或无头浏览器)缺字体,就直接 fallback 成空白。

  • 确保运行环境装了中文字体(如 Ubuntu 装 fonts-wqy-zenhei
  • 开发时用 Chrome 浏览器测试,避免在 Electron 或 Puppeteer 里跑 html2canvas 却没配好字体路径
  • 不要指望 jsPDF.setFont()addImage() 生效——它只影响 text() 方法绘制的文字

滚动区域截不全?别用 scrollY,改用 useCORS: true + allowTaint: false

如果要截图的区域超出视口(比如长表格、带 overflow-y: scroll 的 div),html2canvas 默认只渲染当前可见部分。有人试过先滚到顶部再截图,但异步滚动 + 渲染时机难控,容易截漏。

真正可靠的解法是让 html2canvas 强制渲染整个 DOM 区域,而不是依赖滚动位置。

  • 给目标容器加 style="height: auto; overflow: visible;" 临时撑开(注意别影响原布局)
  • html2canvas 选项里必须设 useCORS: true,否则跨域图片(如 CDN 上的 avatar)会触发 canvas 污染,导致 toDataURL() 报错 Failed to execute 'toDataURL' on 'HTMLCanvasElement'
  • 同时设 allowTaint: false,避免因个别资源加载失败中断整个截图流程
实际导出逻辑就三步:用 html2canvas 渲染整块 DOM → 转成 data URL → 丢给 jsPDF 插入页面。难点不在代码长短,而在每一步的隐式依赖:字体、DPI、CORS、容器尺寸——漏一个,PDF 就不是你看到的那个样子。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
chrome什么意思
chrome什么意思

chrome是浏览器的意思,由Google开发的网络浏览器,它在2008年首次发布,并迅速成为全球最受欢迎的浏览器之一。本专题为大家提供chrome相关的文章、下载、课程内容,供大家免费下载体验。

1025

2023.08.11

chrome无法加载插件怎么办
chrome无法加载插件怎么办

chrome无法加载插件可以通过检查插件是否已正确安装、禁用和启用插件、清除插件缓存、更新浏览器和插件、检查网络连接和尝试在隐身模式下加载插件方法解决。更多关于chrome相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

823

2023.11.06

format在python中的用法
format在python中的用法

Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

866

2023.07.31

python中的format是什么意思
python中的format是什么意思

python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

457

2024.06.27

DOM是什么意思
DOM是什么意思

dom的英文全称是documentobjectmodel,表示文件对象模型,是w3c组织推荐的处理可扩展置标语言的标准编程接口;dom是html文档的内存中对象表示,它提供了使用javascript与网页交互的方式。想了解更多的相关内容,可以阅读本专题下面的文章。

4183

2024.08.14

overflow什么意思
overflow什么意思

overflow是一个用于控制元素溢出内容的属性,当元素的内容超出其指定的尺寸时,overflow属性可以决定如何处理这些溢出的内容。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1839

2024.08.15

html5动画制作有哪些制作方法
html5动画制作有哪些制作方法

html5动画制作方法有使用CSS3动画、使用JavaScript动画库、使用HTML5 Canvas等。想了解更多html5动画制作方法相关内容,可以阅读本专题下面的文章。

544

2023.10.23

常见的编码方式
常见的编码方式

常见的编码方式有ASCII编码、Unicode编码、UTF-8编码、UTF-16编码、GBK编码等。想了解更多编码方式相关内容,可以阅读本专题下面的文章。

644

2023.10.24

Rust内存安全机制与所有权模型深度实践
Rust内存安全机制与所有权模型深度实践

本专题围绕 Rust 语言核心特性展开,深入讲解所有权机制、借用规则、生命周期管理以及智能指针等关键概念。通过系统级开发案例,分析内存安全保障原理与零成本抽象优势,并结合并发场景讲解 Send 与 Sync 特性实现机制。帮助开发者真正理解 Rust 的设计哲学,掌握在高性能与安全性并重场景中的工程实践能力。

4

2026.03.05

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.5万人学习

AngularJS教程
AngularJS教程

共24课时 | 4万人学习

CSS教程
CSS教程

共754课时 | 39.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号