@Pudjak

Как перенести таблицу на новый лист?

Создаю страницу А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, то всё багается и переполненная таблица просто начинает лезть на следующий лист, на котором уже есть текст. Можно ли как-то осуществить разрыв таблицы с переносом на новый лист?
  • Вопрос задан
  • 148 просмотров
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы