我正在开发基于 web 的小型应用程序,用户可以看到 2-3 页长的报告,可以打印为 PDF。我在 stackoverflow /internet 上查看了不同的解决方案,发现了一些打印方面的工作解决方案(内容打印有额外的边距,但我需要解决这个问题)我目前的问题是我无法在浏览器中显示 html 内容页面布局。我能够显示 A4 尺寸的第一页,但一旦内容超出一页,它就好像打印在页面外一样,您可以查看下面的图片
这是CSS
.A4 {
background: white;
width: 21cm;
height: 29.7cm;
display: block;
margin: 0 auto;
padding: 10px 25px;
margin-bottom: 0.5cm;
box-shadow: 0 0 0.5cm rgba(0,0,0,0.5);
}
@media print {
.page-break { display: block; page-break-before: always; }
size: A4 portrait;
}
@media print {
.noprint {display:none;}
.enable-print { display: block; }
}
我正在尝试解决以下问题,
- 如果所有报告都以类似布局的页面显示(另外,如果我可以水平分页而不是长垂直页面显示页面),我会很高兴
- 打印时没有填充问题,所见即所得!
原文由 Ninad Mhatre 发布,翻译遵循 CC BY-SA 4.0 许可协议
你的第二个问题:
您必须将主体边距和填充设置为零。您还需要从 A4 类中删除框阴影、边距、宽度和高度,以便打印多页。
你的第一个问题:
您可以尝试通过计算 scrollheight 来创建分页功能,并不断从页面中删除元素,直到 scollheight 小于页面本身。
示例: https ://jsfiddle.net/tk8rwnav/31/
这个例子在每个元素上都中断。段落不会断言,但你可以实现这个,但这会很快变得复杂。