gpt4 book ai didi

html - A4 页面像 html 中的布局

转载 作者:太空狗 更新时间:2023-10-29 13:11:01 27 4
gpt4 key购买 nike

我正在开发基于 web 的小型应用程序,向用户显示 2-3 页长的报告,可以打印为 PDF。我在 stackoverflow 上查看了不同的解决方案/互联网,并找到了打印方面的一些工作解决方案(内容打印有额外的边距,但我需要解决这个问题)我目前的问题是我无法在浏览器中显示 html 内容,页面布局。我能够显示 A4 尺寸的第一页,但一旦内容超出一页,它就会显示为打印在页面外,您可以查看下面的图片

  1. 页面在浏览器中的显示方式 enter image description here

  2. 打印预览的样子 enter image description here

这是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; }
}

我正在尝试解决以下问题,

  1. 如果所有报告都以类似页面的布局显示(此外,如果我可以水平分页而不是长垂直页面显示页面),我会很高兴
  2. 打印时没有填充问题,所见即所得!

最佳答案

你的第二个问题:

您必须将正文边距和填充设置为零。您还需要从 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/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com