0

0

html如何兼容低版本转pdf_兼容转html为pdf法【思路】

蓮花仙者

蓮花仙者

发布时间:2026-01-17 19:21:02

|

1416人浏览过

|

来源于php中文网

原创

wkhtmltopdf低版本(如0.12.x)因基于旧Qt WebKit内核,不支持Flex/Grid/rem/@media print等现代CSS特性,需降级为table+内联样式、pt单位、绝对路径字体+--font-outline 1等兼容方案。

html如何兼容低版本转pdf_兼容转html为pdf法【思路】

PDF生成时CSS不生效,是因为wkhtmltopdf默认用Qt WebKit内核

低版本 wkhtmltopdf(如0.12.x)基于旧版Qt WebKit,不支持Flex、Grid、rem单位、@media print中部分属性,甚至会忽略 position: fixed。不是HTML写得不对,是渲染引擎根本没实现。

  • 优先确认你用的 wkhtmltopdf --version 输出版本;0.12.6以下基本不建议用于现代CSS
  • 避免用 display: gridgap —— Qt WebKit 538(对应wkhtmltopdf 0.12.x)完全不识别
  • font-size: 1.2rem 在某些0.12.x中会被解析为 1.2px,改用 em 或绝对单位(pt 更稳)
  • @media screen@media print 分离样式时,低版本可能只认 @media print,建议统一用后者并禁用屏幕媒体查询干扰

table布局+内联style是低版本最稳的兜底方案

当必须兼容 wkhtmltopdf 0.12.4 或更老版本时,放弃语义化结构和外部CSS,直接用 <table> + 全内联 style 是最快落地的方案。

  • 所有宽度用 width: 200pxwidth: 30%,不用 max-width(不支持)
  • 边框统一用 border: 1px solid #000,避免 border-collapse: collapse 失效导致双线
  • 文字垂直居中vertical-align: middle + line-height 匹配单元格高,别依赖 flex
  • 图片务必加 heightwidth 属性,否则低版本常渲染为空白或错位
<table style="width: 100%; border: 1px solid #000; border-collapse: collapse;">
  <tr>
    <td style="padding: 8px; border: 1px solid #000; width: 30%;">姓名</td>
    <td style="padding: 8px; border: 1px solid #000;"><span style="font-family: SimSun; font-size: 12pt;">张三</span></td>
  </tr>
</table>

header/footer在低版本里必须用--header-html参数注入

wkhtmltopdf 低版本不支持HTML内 @page@top-center 等规则,页眉页脚只能通过命令行参数注入独立HTML片段,且该HTML不能含外部CSS或JS。

  • 页眉HTML里只允许内联样式,且不能用 % 单位(如 width: 100% 会失效),推荐固定像素宽
  • 变量如页码需用占位符:<div style="text-align:right">第 [page] 页,共 [toPage] 页</div>
  • 如果页眉内容超长换行错位,加 white-space: nowrap + overflow: hidden 控制
  • 注意:--header-spacing 10 才能让页眉和正文保持10px间距,漏掉这个参数会导致页眉压正文

字体嵌入失败?先检查TTF路径和--font-outline参数

低版本 wkhtmltopdf 对中文字体支持极弱,即使指定了 @font-face,也大概率回退到默认无衬线字体。真正起作用的是 --font-outline 参数强制轮廓渲染。

Yodayo
Yodayo

一个专为动漫迷和vTuber打造的AI艺术创作平台、交流社区

下载

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

  • 确保TTF文件路径是绝对路径,且wkhtmltopdf进程有读取权限(Docker里尤其注意挂载)
  • 中文必须用TrueType(.ttf),OpenType(.otf)在0.12.x中基本不可用
  • 启动命令里加上 --font-outline 1,这是激活字体轮廓的关键开关,缺了就显示方块
  • CSS中指定字体时,font-family 值必须和系统注册名一致(如Windows下用 "SimSun",Linux下用 "WenQuanYi Micro Hei"),不能只写文件名

容易被忽略的一点:生成PDF前,先用 wkhtmltopdf --versionwkhtmltopdf --fonts 确认字体列表是否包含你要的中文字体。没有就别折腾CSS了。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
视频后缀名都有哪些
视频后缀名都有哪些

视频后缀名都有avi、mpg、mpeg、rm、rmvb、flv、wmv、mov、mkv、ASF、M1V、M2V、MPE、QT、VOB、RA、RMJ、RMS、RAM、等等。更多关于视频后缀名的相关知识,详情请看本专题下面的文章,php中文网欢迎大家前来学习。

3877

2023.10.31

C++ Qt图形开发
C++ Qt图形开发

本专题专注于 C++ Qt框架在图形界面开发中的应用,系统讲解窗口设计、信号与槽机制、界面布局、事件处理、数据库连接与跨平台打包等核心技能,通过多个桌面应用项目实战,帮助学员快速掌握 Qt 框架并独立完成跨平台GUI软件的开发。

76

2025.08.15

C++ 图形界面开发基础(Qt方向)
C++ 图形界面开发基础(Qt方向)

本专题系统讲解 使用 C++ 与 Qt 进行图形界面(GUI)开发的核心技能,内容涵盖 Qt 项目结构、窗口组件、信号与槽机制、事件处理、布局管理、资源管理,以及跨平台编译与打包流程。通过多个小型桌面应用实战案例,帮助学习者掌握从界面设计到功能实现的完整 GUI 开发能力。

111

2025.12.05

python中print函数的用法
python中print函数的用法

python中print函数的语法是“print(value1, value2, ..., sep=' ', end=' ', file=sys.stdout, flush=False)”。本专题为大家提供print相关的文章、下载、课程内容,供大家免费下载体验。

192

2023.09.27

python print用法与作用
python print用法与作用

本专题整合了python print的用法、作用、函数功能相关内容,阅读专题下面的文章了解更多详细教程。

19

2026.02.03

js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

530

2023.06.20

js获取当前时间
js获取当前时间

JS全称JavaScript,是一种具有函数优先的轻量级,解释型或即时编译型的编程语言;它是一种属于网络的高级脚本语言,主要用于Web,常用来为网页添加各式各样的动态功能。js怎么获取当前时间呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

576

2023.07.28

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

760

2023.08.03

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

76

2026.03.11

热门下载

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

精品课程

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

共14课时 | 0.9万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.6万人学习

CSS教程
CSS教程

共754课时 | 42.5万人学习

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

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