14

我正在使用 twitter-bootstrap 布局生成table打印。该页面有多个tbody内部table; 在打印页面时,它需要page-break-after一个tbody

为此,我应用了

@media print {
    tbody{
        page-break-after: auto;
        page-break-inside: avoid;
        border: none !important;
        margin-bottom: 20px !important;
    }
}

问题是什么?

  • 将样式page-break-after应用于 atbody时,分页符不起作用,请参见此处

  • 但是当应用display:block到时,它给出了想要的结果,但是表格的布局在更改为See Heretbody后被扭曲了tbody display:table-row-groupdisplay:block

我想在 tbody 使用page-break-after: auto;.

场景如下

桌子

4

4 回答 4

19

这是一个已知问题。page-break属性仅适用于块级元素。

这就是为什么您的tbody. 当您明确地tbody从其 更改display: table-row-group为 时display: block,分页符将开始应用。但是,这会破坏你的桌子的布局。

根据规格:http ://www.w3.org/TR/CSS21/page.html#page-break-props

用户代理必须将这些属性应用于根元素的正常流程中的块级元素。用户代理也可以将这些属性应用于其他元素,例如“table-row”元素

尽管规范说用户代理可以将这些属性应用于,但“可能table-row”这个词发挥了作用,并且在不同的实现中行为并不统一。

解决方案:

将分页符应用于您的块级伪元素,tbody而不是直接将其应用于tbody.

像这样:

tbody::after {
    content: ''; display: block;
    page-break-after: always;
    page-break-inside: avoid;
    page-break-before: avoid;        
}

这是您的工作小提琴:http: //jsfiddle.net/abhitalks/DTcHh/3054/

另外,请注意,仅此一项并不能解决您的所有问题。您必须仔细定义页面上下文以及适当的边距和尺寸以适合您的用例。

这会给你一个开始:

@page {
    size: A4;
    margin: 0;
}
@media print {
    html, body {
        width: 210mm;
        height: 297mm;
    }
    ...
}

这是一个带有一个非常简单的示例的片段来尝试一下。要进行测试,请检查打印预览,应该有两个分页符,每个tbody.

片段

table, th, td { border: 1px solid gray; border-collapse: collapse; }
th, td { padding: 8px; }
tbody:first-of-type { background-color: #eee; }

@page {
    size: A4;
    margin: 0;
}
@media print {
    html, body {
        width: 210mm;
        height: 297mm;
    }
    tbody::after {
        content: ''; display: block;
        page-break-after: always;
        page-break-inside: avoid;
        page-break-before: avoid;        
    }
    
  
}
<div> 
    <a href="#" onClick="window.print();">Print</a>
</div>
<hr />
<table>
    <thead>
		<tr>
			<th>Head 1</th>
			<th>Head 2</th>
			<th>Head 3</th>
		</tr>
    </thead>
	<tbody>
		<tr>
			<td>Row 1 Cell 1</td>
			<td>Row 1 Cell 2</td>
			<td>Row 1 Cell 3</td>
		</tr>
		<tr>
			<td>Row 2 Cell 1</td>
			<td>Row 2 Cell 2</td>
			<td>Row 2 Cell 3</td>
		</tr>
	</tbody>
	<tbody>
		<tr>
			<td>Row 3 Cell 1</td>
			<td>Row 3 Cell 2</td>
			<td>Row 3 Cell 3</td>
		</tr>
		<tr>
			<td>Row 4 Cell 1</td>
			<td>Row 4 Cell 2</td>
			<td>Row 4 Cell 3</td>
		</tr>
	</tbody>
    <tfoot>
		<tr>
			<th>Foot 1</th>
			<th>Foot 2</th>
			<th>Foot 3</th>
		</tr>	
    </tfoot>
</table>

免责声明:我仅针对 Chrome v39 对其进行了测试。您需要应用自己的测试。

.

于 2015-01-03T12:35:14.307 回答
0

我解决了它包裹桌子

<div style="display: block; break-inside: avoid">
   <table>
      <tr>
         <td>
            Col 1
         </td>
         <td>
            Col 2
         </td>
      </tr>
   </table>
   <p style="page-break-after: always;"> </p>
</div>

于 2021-10-10T14:40:59.490 回答
0

我通过关闭和打开一个新表而不是在<tbody>. 在表格 css 中,您可以放置​​:

display: block;

并且分页符在那里工作而不会破坏表格的布局。

于 2020-07-10T08:46:38.810 回答
0

这样做是可能的:

tbody {
    display: block;
    width: 100%;
    page-break-after: always;
    page-break-inside: avoid;
    page-break-before: avoid;
}
于 2018-04-24T16:49:05.867 回答