0

0

如何在 HTML 打印为 PDF 时正确实现多列布局

心靈之曲

心靈之曲

发布时间:2026-02-20 09:30:11

|

782人浏览过

|

来源于php中文网

原创

如何在 HTML 打印为 PDF 时正确实现多列布局

本文详解如何通过纯 css grid 实现 html 页面在打印为 pdf 时稳定、响应式的多列布局,无需额外库,兼容主流浏览器及 pdf 打印引擎(如 chrome devtools、wkhtmltopdf)。

本文详解如何通过纯 css grid 实现 html 页面在打印为 pdf 时稳定、响应式的多列布局,无需额外库,兼容主流浏览器及 pdf 打印引擎(如 chrome devtools、wkhtmltopdf)。

在将 HTML 导出为 PDF 的场景中(例如使用浏览器“打印→另存为 PDF”、Puppeteer 或 wkhtmltopdf 工具),开发者常遇到 CSS 布局失效问题——尤其是 column-count 或 Flexbox 在部分打印上下文中渲染异常。CSS Grid 是目前最可靠、语义清晰且打印友好的多列解决方案,因其基于显式轨道定义,不依赖流式重排,在 PDF 生成阶段能被准确解析。

以下是一个生产就绪的三列布局示例,已通过 Chrome、Edge 和 wkhtmltopdf 12.x 实测验证:

<!DOCTYPE html>
<html lang="zh-CN">
<head>
  <meta charset="UTF-8">
  <title>PDF 友好型多列 HTML</title>
  <style>
    /* 关键:启用 Grid 布局 */
    .row {
      display: grid;
      /* 推荐使用 repeat() 提升可维护性 */
      grid-template-columns: repeat(3, 1fr);
      gap: 12px; /* 列间间距,比 margin 更可控 */
      margin-bottom: 16px;
    }

    .column {
      background-color: #f9f9f9;
      padding: 12px 16px;
      border: 1px solid #ddd;
      font-size: 14px;
      line-height: 1.5;
    }

    /* 打印适配增强(可选但强烈推荐) */
    @media print {
      body {
        margin: 0;
        font-size: 12pt; /* 统一打印字体大小 */
      }
      .row {
        break-inside: avoid; /* 防止行被跨页截断 */
      }
      .column {
        break-inside: avoid; /* 确保单列内容不跨页断裂 */
      }
    }
  </style>
</head>
<body>
  <div class="row">
    <div class="column"><p><strong>第一列</strong><br>客户信息、联系人、地址等结构化数据</p></div>
    <div class="column"><p><strong>第二列</strong><br>订单编号、日期、状态标签</p><p><span>立即学习</span>“<a href="https://pan.quark.cn/s/cb6835dc7db1" style="text-decoration: underline !important; color: blue; font-weight: bolder;" rel="nofollow" target="_blank">前端免费学习笔记(深入)</a>”;</p></div>
    <div class="column"><p><strong>第三列</strong><br>金额汇总、税率、应付总额</p><div class="aritcle_card flexRow">
                                                        <div class="artcardd flexRow">
                                                                <a class="aritcle_card_img" href="/ai/1573" title="NexChatGPT"><img
                                                                                src="https://img.php.cn/upload/ai_manual/000/969/633/68b79f3496bf8716.png" alt="NexChatGPT"  onerror="this.onerror='';this.src='/static/lhimages/moren/morentu.png'" ></a>
                                                                <div class="aritcle_card_info flexColumn">
                                                                        <a href="/ai/1573" title="NexChatGPT">NexChatGPT</a>
                                                                        <p>火爆全网的IDEA插件,支持IDEA全家桶</p>
                                                                </div>
                                                                <a href="/ai/1573" title="NexChatGPT" class="aritcle_card_btn flexRow flexcenter"><b></b><span>下载</span> </a>
                                                        </div>
                                                </div></div>
  </div>

  <div class="row">
    <div class="column"><p><strong>项目明细</strong><br>商品 A × 2<br>单价 ¥120.00</p></div>
    <div class="column"><p><strong>项目明细</strong><br>商品 B × 1<br>单价 ¥85.50</p></div>
    <div class="column"><p><strong>项目明细</strong><br>运费<br>¥15.00</p></div>
  </div>
</body>
</html>

关键实践建议

  • 避免 float 和 inline-block:它们在打印中易导致列宽塌陷或换行错乱;
  • 慎用 column-count:虽语义直观,但在 PDF 渲染中常出现内容重叠或列高不一致;
  • 始终添加 @media print 规则:控制页边距、字体、分页行为(如 break-inside: avoid);
  • 测试真实导出流程:在 Chrome 中按 Ctrl+P → “另存为 PDF”,而非仅依赖屏幕预览;
  • 动态列数扩展:只需修改 repeat(N, 1fr) 中的 N,例如 repeat(4, 25%) 或 repeat(auto-fit, minmax(200px, 1fr)))(后者需确保容器有明确宽度)。

总结:纯 CSS Grid 是 HTML → PDF 多列布局的黄金标准——零依赖、高兼容、易维护。只要规避浮动与复杂媒体查询,即可生成专业、稳定的打印文档。

相关文章

HTML速学教程(入门课程)
HTML速学教程(入门课程)

HTML怎么学习?HTML怎么入门?HTML在哪学?HTML怎么学才快?不用担心,这里为大家提供了HTML速学教程(入门课程),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

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

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

966

2023.08.11

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

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

793

2023.11.06

chrome什么意思
chrome什么意思

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

966

2023.08.11

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

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

793

2023.11.06

edge是什么浏览器
edge是什么浏览器

Edge是一款由Microsoft开发的网页浏览器,是Windows 10操作系统中默认的浏览器,其目标是提供更快、更安全、更现代化的浏览器体验。本专题为大家提供edge浏览器相关的文章、下载、课程内容,供大家免费下载体验。

1581

2023.08.21

IE浏览器自动跳转EDGE如何恢复
IE浏览器自动跳转EDGE如何恢复

ie浏览器自动跳转edge的解决办法:1、更改默认浏览器设置;2、阻止edge浏览器的自动跳转;3、更改超链接的默认打开方式;4、禁用“快速网页查看器”;5、卸载edge浏览器;6、检查第三方插件或应用程序等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

392

2024.03.05

如何解决Edge打开但没有标题的问题
如何解决Edge打开但没有标题的问题

若 Microsoft Edge 浏览器打开后无标题(窗口空白或标题栏缺失),可尝试以下方法解决: 重启 Edge:关闭所有窗口,重新启动浏览器。 重置窗口布局:右击任务栏 Edge 图标 → 选择「最大化」或「还原」。 禁用扩展:进入 edge://extensions 临时关闭插件测试。 重置浏览器设置:前往 edge://settings/reset 恢复默认配置。 更新或重装 Edge:检查最新版本,或通过控制面板修复

988

2025.04.24

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

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

192

2023.09.27

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

660

2026.02.13

热门下载

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

精品课程

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

共46课时 | 3.4万人学习

AngularJS教程
AngularJS教程

共24课时 | 3.7万人学习

CSS教程
CSS教程

共754课时 | 33.6万人学习

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

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