Создаю страницу А4, на эту страницу вывожу данные из базы данных в виде таблицы. Но дело в том, что данных может оказаться настолько много, что на страницу они в итоге не влезут.
Страница:
<div class="A4">
Тут таблица
</div>
Стили:
.A4 {
background: white;
width: 21cm;
height: 29.7cm;
display: block;
margin: 0 auto;
padding-left:60px;padding-right:60px;
padding-top:30px;padding-bottom:60px;
margin-bottom: 0.5cm;
box-shadow: 0 0 0.5cm rgba(0, 0, 0, 0.5);
box-sizing: border-box;
font-size: 12pt;
}
@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;
}
}
Скрипт на создание нового листа при переполнении:
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);
});
});
В итоге при переполнении текстом создаётся новый лист, на котором продолжается текст.
Но если я получаю таблицу больше размера А4, то всё багается и переполненная таблица просто начинает лезть на следующий лист, на котором уже есть текст. Можно ли как-то осуществить разрыв таблицы с переносом на новый лист?