作者热门文章
- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在开发基于 web 的小型应用程序,向用户显示 2-3 页长的报告,可以打印为 PDF。我在 stackoverflow 上查看了不同的解决方案/互联网,并找到了打印方面的一些工作解决方案(内容打印有额外的边距,但我需要解决这个问题)我目前的问题是我无法在浏览器中显示 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; }
}
我正在尝试解决以下问题,
最佳答案
你的第二个问题:
您必须将正文边距和填充设置为零。您还需要从 A4 类中删除框阴影、边距、宽度和高度,以便打印多页。
.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);
overflow-y: scroll;
box-sizing: border-box;
}
@media print {
.page-break {
display: block;
page-break-before: always;
}
size: A4 portrait;
}
@media print {
body {
margin: 0;
padding: 0;
}
.A4 {
box-shadow: none;
margin: 0;
width: auto;
height: auto;
}
.noprint {
display: none;
}
.enable-print {
display: block;
}
}
您的第一个问题:
您可以尝试通过计算 scrollheight 来创建分页功能,并不断从页面中删除元素,直到 scollheight 小于页面本身。
示例:https://jsfiddle.net/tk8rwnav/31/
var max_pages = 100;
var page_count = 0;
function snipMe() {
page_count++;
if (page_count > max_pages) {
return;
}
var long = $(this)[0].scrollHeight - Math.ceil($(this).innerHeight());
var children = $(this).children().toArray();
var removed = [];
while (long > 0 && children.length > 0) {
var child = children.pop();
$(child).detach();
removed.unshift(child);
long = $(this)[0].scrollHeight - Math.ceil($(this).innerHeight());
}
if (removed.length > 0) {
var a4 = $('<div class="A4"></div>');
a4.append(removed);
$(this).after(a4);
snipMe.call(a4[0]);
}
}
$(document).ready(function() {
$('.A4').each(function() {
snipMe.call(this);
});
});
此示例在每个元素上都中断。段落不会中断,但您可以实现它,但这会很快变得复杂。
关于html - A4 页面像 html 中的布局,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39486352/
我是一名优秀的程序员,十分优秀!