0

0

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

蓮花仙者

蓮花仙者

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

|

996人浏览过

|

来源于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,直接用

+ 全内联 style 是最快落地的方案。
  • 所有宽度用 width: 200pxwidth: 30%,不用 max-width(不支持)
  • 边框统一用 border: 1px solid #000,避免 border-collapse: collapse 失效导致双线
  • 文字垂直居中vertical-align: middle + line-height 匹配单元格高,别依赖 flex
  • 图片务必加 heightwidth 属性,否则低版本常渲染为空白或错位
姓名 张三

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

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

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

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

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

九歌
九歌

九歌--人工智能诗歌写作系统

下载

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

  • 确保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了。

相关专题

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

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

3455

2023.10.31

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

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

68

2025.08.15

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

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

54

2025.12.05

css
css

css是层叠样式表,用来表现HTML或XML等文件样式的计算机语言,不仅可以静态地修饰网页,还可以配合各种脚本语言动态地对网页各元素进行格式化。php中文网还为大家带来html的相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

524

2023.06.15

css居中
css居中

css居中:1、通过“margin: 0 auto; text-align: center”实现水平居中;2、通过“display:flex”实现水平居中;3、通过“display:table-cell”和“margin-left”实现居中。本专题为大家提供css居中的相关的文章、下载、课程内容,供大家免费下载体验。

263

2023.07.27

css如何插入图片
css如何插入图片

cssCSS是层叠样式表(Cascading Style Sheets)的缩写。它是一种用于描述网页或应用程序外观和样式的标记语言。CSS可以控制网页的字体、颜色、布局、大小、背景、边框等方面,使得网页的外观更加美观和易于阅读。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

754

2023.07.28

css超出显示...
css超出显示...

在CSS中,当文本内容超出容器的宽度或高度时,可以使用省略号来表示被隐藏的文本内容。本专题为大家提供css超出显示...的相关文章,相关教程,供大家免费体验。

539

2023.08.01

css字体颜色
css字体颜色

CSS中,字体颜色可以通过属性color来设置,用于控制文本的前景色,字体颜色在网页设计中起到很重要的作用,具有以下表现作用:1、提升可读性;2、强调重点信息;3、营造氛围和美感;4、用于呈现品牌标识或与品牌形象相符的风格。

760

2023.08.10

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

43

2026.01.16

热门下载

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

精品课程

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

共14课时 | 0.8万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 2.9万人学习

CSS教程
CSS教程

共754课时 | 19.8万人学习

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

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