首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >修正列中的孤立标题

修正列中的孤立标题
EN

Stack Overflow用户
提问于 2017-10-11 07:42:22
回答 3查看 118关注 0票数 0

我目前被困在一个CSS打印问题上,这个问题是打印列而没有孤立标题,如下面的示例所示:

https://codepen.io/sjeannin/pen/wrXoRG

代码语言:javascript
复制
<div class="two-columns">
  <h1>Hello, Title</h1>
  <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.</p>
  <p>Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.</p>
  <h1>Other title, world!</h1>
  <h2> Subtitle, world</h2>
  <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.</p>
  <p>Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.</p>

</div>

.two-columns {
  column-count: 2;
}

h1, h2 {
  break-after: avoid;
}

我的目标是用谷歌Chrome无头打印一个结构良好、长达40页的文档的CSS表格。不幸的是,我在呈现的文档中遇到了一些孤儿:在前面的示例中,我更希望在第二列中有第二个标题及其相关的内容。

有没有一种CSS的方式来使这个工作?应该在文档代码中使用自定义div来强制列跳转吗?

谢谢!

~spj

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2017-10-11 13:56:06

最后,我提出了一种解决方案,适用于我的90%的案例:

代码语言:javascript
复制
* + h2,* + h3,* + h4,* + h5,* + h6 {
    break-inside: avoid-column!important;
    break-after: avoid-column!important;
    page-break-inside: avoid!important;
    page-break-after: avoid!important;
    -webkit-column-break-inside: avoid!important;
    -webkit-column-break-after: avoid!important;
}
h2 + *, h3 + *, h4 + *, h5 + *, h6 + * {
    break-before: avoid-column!important;
    page-break-before: avoid!important;
    -webkit-column-break-before: avoid!important;
}
h1:not(:first-child) {
    break-before: column;
}

(这是一个临时的解决方案,因为我知道它很难看,而且我仍然在寻找一种通用的方法来打印一个PDF和零h1-h6孤儿)。

票数 0
EN

Stack Overflow用户

发布于 2017-10-11 08:00:11

使用:不是(X)选择器怎么样?选择除第一个在列之前中断的H1之外的所有?

代码语言:javascript
复制
h1:not(:first-child) {
  break-before: column;
}
票数 0
EN

Stack Overflow用户

发布于 2017-10-11 17:48:04

问题来自谷歌Chrome本身,我尝试了Weasyprint,它的工作像一个魅力时,使用我刚才写的丑陋的CSS!

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/46682546

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档