我正在为一个软件编写一个插件,它可以收集大量的项目,并将它们弹出到Cocoa WebView中的HTML中(它使用WebKit作为它的渲染器,所以基本上你可以假设这个HTML文件是在Safari中打开的)。

它生成的div具有动态高度,但变化不大。它们通常在200px左右。不管怎样,每个文档大约有600个这样的项目,我很难把它打印出来。除非我很幸运,否则每页的底部和顶部都有一个条目被切成两半,这使得实际使用打印输出非常困难。

我尝试过前破页、后破页、内破页,三种方法的组合都没有用。我认为可能是WebKit没有正确地呈现指令,或者可能是我对如何使用它们缺乏理解。无论如何,我需要帮助。如何防止打印时DIVs减半?


当前回答

page-break-inside:避免;绝对不能在webkit中工作,事实上已经是一个已知的问题5年多了https://bugs.webkit.org/show_bug.cgi?id=5097

就我的研究而言,还没有已知的方法来实现这一点(我正在研究自己的破解方法)

我可以给你的建议是,要在FF中实现这个功能,用overflow: auto(注意不要因为容器大小太小而导致奇怪的滚动条显示)来包装您不想在DIV(或任何容器)中中断的内容。

遗憾的是,FF是我唯一能做到这一点的浏览器,而webkit是我更担心的一个。

其他回答

我也不得不处理wkhtmltopdf。

我使用Bootstrap 3.3.7作为框架,需要避免在.row元素上分页。

我使用这些设置完成了工作:

.myContainer {
    display: grid;
    page-break-inside: avoid;
}

不需要用@media print来包装

可能的page-break-after值有:auto、always、avoid、left、right

我认为你不能在绝对定位的元素上使用page-break-after属性。

我也有同样的问题,但还没有解决办法。page-break-inside不能在浏览器上工作,但在Opera上。另一种选择可能是使用page-break-after: avoid;在div的所有子元素上保持在一起…但在我的测试中,回避属性不起作用。在Firefox中…

在所有流行的浏览器中工作的是强制换页,使用例如。page-break-after:总是

page-break-inside:避免;绝对不能在webkit中工作,事实上已经是一个已知的问题5年多了https://bugs.webkit.org/show_bug.cgi?id=5097

就我的研究而言,还没有已知的方法来实现这一点(我正在研究自己的破解方法)

我可以给你的建议是,要在FF中实现这个功能,用overflow: auto(注意不要因为容器大小太小而导致奇怪的滚动条显示)来包装您不想在DIV(或任何容器)中中断的内容。

遗憾的是,FF是我唯一能做到这一点的浏览器,而webkit是我更担心的一个。

使用break-inside应该有效:

@media print {
  div {
    break-inside: avoid;
  }
}

它适用于所有主流浏览器:

Chrome 50 +。 艾奇12 +。 Firefox 65 +。 歌剧37 +。 Safari 10 +。

使用page-break-inside:避免;相反,应该也工作,但已经完全反对的突破:避免。