Я пробую две вещи:
- Показывать контент в модальном виде, как он появится на странице формата A4
- windows.print() модальный на странице A4 через основные браузеры
Ниже приведен мой CSS:
.page {
width: 210mm;
min-height: 297mm;
padding: 20mm;
margin: 10mm auto;
border: 1px #D3D3D3 solid;
border-radius: 5px;
background: white;
box-shadow: 0 0 5px rgba(0, 0, 0, 0.1);
}
.subpage {
padding: 1cm;
border: 5px black solid;
height: 257mm;
outline: 2cm #FFEAEA solid;
}
@page {
size: A4;
margin: 0;
}
@media print {
html, body {
margin:0 !important;
padding:0 !important;
height:100% !important;
visibility: hidden;
}
.page .subpage .col-md-12,.col-lg-12{
float:left;
width:100%;
}
.page .subpage {
padding: 1cm;
border: 5px black solid;
height: 257mm;
outline: 2cm #FFEAEA solid;
position:absolute;
}
.page {
visibility: visible;
}
}
Но так выглядит при вызове window.print()
при нажатии кнопки:
Что я здесь делаю неправильно? Относительный новичок CSS, посмотрел на кучу вопросов SO и других ресурсов, но, похоже, не может понять этого.
UPDATE: я использовал z-index: 9999 и ширину: 140% для получения модального контента (например, class= "page" ), чтобы покрыть ширину страницы A4. Не думайте, что это лучшее решение, также не может получить высоту, чтобы растянуть весь 297 мм; высота по-прежнему такая же, как показано на втором изображении. 140% отлично смотрится на pdf, сохраненном через Chrome, обрезается (понятно) в firefox и отображается как пустой pdf в IE. Обновлен CSS:
@media print .page {z-index: 9999;padding: 20mm;margin: 10mm auto;width: 140%;height:100%;position: fixed;top: 15mm;bottom:0;left: 20mm;visibility:visible;}