猿问

将页面打印/保存为 PDF,但如果某个元素被截断,则在它之前添加一个分页符

我有一个页面需要打印为 PDF(另存为 PDF 或仅使用浏览器打印对话框),类似于:


div {

  outline: red solid 1px;

}

body {

    margin-left: 30vw;

    margin-right: 30vw;

}

<div>

Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's standard dummy text ever since the 1500s, when an unknown printer took a galley of type and scrambled it to make a type specimen book. It has survived not only five centuries, but also the leap into electronic typesetting, remaining essentially unchanged. It was popularised in the 1960s with the release of Letraset sheets containing Lorem Ipsum passages, and more recently with desktop publishing software like Aldus PageMaker including versions of Lorem Ipsum.

</div>

<br>

<div>

It is a long established fact that a reader will be distracted by the readable content of a page when looking at its layout. The point of using Lorem Ipsum is that it has a more-or-less normal distribution of letters, as opposed to using 'Content here, content here', making it look like readable English. Many desktop publishing packages and web page editors now use Lorem Ipsum as their default model text, and a search for 'lorem ipsum' will uncover many web sites still in their infancy. Various versions have evolved over the years, sometimes by accident, sometimes on purpose (injected humour and the like).

</div>

<br>

<div>


该网站的内容较长,可以放在一个页面中,因此当我尝试打印时它会被切断。我希望在每个段之前插入一个分页符,如果它会在中间被剪切,那么段之间只有分页符。我目前正在尝试使用html2pdf.js避免所有分页符模式:


html2pdf().set({

  pagebreak: { mode: ['avoid-all', 'css', 'legacy'] }

});

但这似乎没有任何作用。我可以使用手动标记(将类添加html2pdf__page-break到应该在分页符之前的元素中),但是我经常修改这个站点,而且我不想每次对站点进行更改时都必须返回元素更长或更短。


Helenr
浏览 407回答 1
1回答
随时随地看视频慕课网APP

相关分类

JavaScript
我要回答