Печать таблицы HTML
Хорошо, моя настоящая таблица — это HTML-таблица, которая извлекает информацию из базы данных MySQL. Я использую php, когда я пытаюсь напечатать все, что вижу, это HTML-материал.
я думаю, что есть проблема в вашем HTML, почему вы не проверяете предварительный просмотр перед печатью
Вы можете изменить его в соответствии с вашими потребностями.
Фактически он открывает новое окно, содержащее этот элемент, и печатает его.Один из подходов — открыть таблицу на новой странице. Вы можете сделать это с помощью отправки javascript формы на новую страницу, передавая все переменные, необходимые для создания вашей таблицы.
Затем поместите код для создания таблицы на новой странице вместе с вашей кнопкой. Если вы не хотите кнопку, вы все равно можете вызвать функцию печати, просто обратившись к вашей функции javascript в свой HTML-код:
Вы также можете открыть таблицу на новой странице с помощью метода javascript window.open(). Это хороший подход, если у вас слишком много переменных для перехода в новое окно. Вы можете передать несколько мелких вещей через переменные url, которые вы можете настроить в своей функции javascript.
Я также использовал подход, в котором я остаюсь на одной странице, и пользователь может нажать на что-то, чтобы удалить отображение всего, кроме таблицы. Это делается путем обертывания съемного материала в div
Когда пользователь делает клик, функция javascript, которая запускается, устанавливает отображение для этого идентификатора «none».
document.getElementById('remove').style.display = 'none';
Второй щелчок восстанавливает дисплей. Щелчок не обязательно должен быть на кнопке. Я использовал его в заголовке отчета, чтобы все исчезло, кроме самого отчета. Вы можете поместить его в одну из своих ячеек таблицы.
В любом случае метод window.print() откроет только окно для принтера; пользователь может затем настроить задание на печать по своему усмотрению, убедиться, что принтер включен и т.д.
How to Handle Page Breaks when Printing a Large HTML Table
Read our snippet if you need to print an HTML table with many rows over multiple pages.
Please note that in order to examine the results more efficiently, you need to create an «index.html» file in your local machine and try out the codes locally to see the results better. You also need to press «CTRL + P» if you use Windows or «CMD + P» if using Mac to see the results on the print page.
Example of handling page breaks when printing a large table:
html> html> head> style> @media print < table < page-break-inside: avoid; > thead < display: table-header-group; > > style> head> body> table> thead> tr> th>Column 1 th> th>Column 2 th> th>Column 3 th> tr> thead> tbody> tr> td>Row 1, Column 1 td> td>Row 1, Column 2 td> td>Row 1, Column 3 td> tr> tbody> table> body> html>
We also set display: table-header-group; on the thead element. This ensures that the table header (the tr containing the column headings) is repeated on each page, which makes it easier to understand the content on each page of the printed table.
The rest of the HTML is a basic table with a header row ( thead ) and a body ( tbody ) containing multiple rows ( tr ) of data. Note that this example doesn’t include any specific page breaks within the table, as it assumes the table will fit on a single page.
Page breaks can sometimes be tricky to handle, and there may be some variations in behavior across different browsers. It’s always a good idea to test your code on multiple browsers and adjust as needed. If you’re encountering issues with page breaks in a specific browser, you can try using different CSS properties or approaches to achieve the desired result.
Avoiding footer on every page break
To prevent a table footer from being displayed on every page break within the table body, you can add the following CSS rule:
tfoot < display: table-footer-group; >
This will ensure that the table footer is only displayed at the end of the table, rather than on every page break within the table body.
html> html> head> style> tfoot < display: table-footer-group; > style> head> body> table> thead> tr> th>Column 1 th> th>Column 2 th> th>Column 3 th> tr> thead> tbody> tr> td>Row 1, Column 1 td> td>Row 1, Column 2 td> td>Row 1, Column 3 td> tr> tr> td>Row 2, Column 1 td> td>Row 2, Column 2 td> td>Row 2, Column 3 td> tr> tr> td>Row 3, Column 1 td> td>Row 3, Column 2 td> td>Row 3, Column 3 td> tr> tbody> tfoot> tr> td>Footer 1 td> td>Footer 2 td> td>Footer 3 td> tr> tfoot> table> body> html>
Breaking after a specific row
To break after a specific row, you can use the nth-child selector in combination with the page-break-after property. For example, to break after every 5th row, you can use the following CSS:
tr:nth-child(5n) < page-break-after: always; >
This will force a page break after every 5th row.
Here’s an example of how to break a large HTML table into pages after a specific number of rows, in this case 5 rows per page:
html> html> head> style> @media print < table < page-break-inside: avoid; > tr < break-inside: avoid; > tbody < display: block; > tbody tr:nth-child(5n + 1) < page-break-before: always; > > style> head> body> table> thead> tr> th>Column 1 th> th>Column 2 th> th>Column 3 th> tr> thead> tbody> tr> td>Row 1, Column 1 td> td>Row 1, Column 2 td> td>Row 1, Column 3 td> tr> tr> td>Row 2, Column 1 td> td>Row 2, Column 2 td> td>Row 2, Column 3 td> tr> tr> td>Row 3, Column 1 td> td>Row 3, Column 2 td> td>Row 3, Column 3 td> tr> tr> td>Row 4, Column 1 td> td>Row 4, Column 2 td> td>Row 4, Column 3 td> tr> tr> td>Row 5, Column 1 td> td>Row 5, Column 2 td> td>Row 5, Column 3 td> tr> tr> td>Row 6, Column 1 td> td>Row 6, Column 2 td> td>Row 6, Column 3 td> tr> tr> td>Row 7, Column 1 td> td>Row 7, Column 2 td> td>Row 7, Column 3 td> tr> tbody> table> body> html>
In this example, we’re using the @media print rule to apply print-specific styles to the table. We’re setting page-break-inside: avoid; on the table to ensure that table rows aren’t split across pages, and break-inside: avoid; on the table rows to prevent them from being split. We’re also setting display: block; on the table body to ensure that it takes up the full width of the page.
Finally, we’re using the nth-child selector to select every 5th row in the table body and applying page-break-before: always; to force a page break before that row. This results in 5 rows per page.
Please note that the page-break-* properties have been updated to break-* in newer versions of browsers. You can use the updated properties for more consistent behavior across different browsers.
Печать таблицы HTML
Хорошо, моя настоящая таблица — это HTML-таблица, которая извлекает информацию из базы данных MySQL. Я использую php, когда я пытаюсь напечатать все, что вижу, это HTML-материал.
я думаю, что есть проблема в вашем HTML, почему вы не проверяете предварительный просмотр перед печатью
Вы можете изменить его в соответствии с вашими потребностями.
Фактически он открывает новое окно, содержащее этот элемент, и печатает его.Один из подходов — открыть таблицу на новой странице. Вы можете сделать это с помощью отправки javascript формы на новую страницу, передавая все переменные, необходимые для создания вашей таблицы.
Затем поместите код для создания таблицы на новой странице вместе с вашей кнопкой. Если вы не хотите кнопку, вы все равно можете вызвать функцию печати, просто обратившись к вашей функции javascript в свой HTML-код:
Вы также можете открыть таблицу на новой странице с помощью метода javascript window.open(). Это хороший подход, если у вас слишком много переменных для перехода в новое окно. Вы можете передать несколько мелких вещей через переменные url, которые вы можете настроить в своей функции javascript.
Я также использовал подход, в котором я остаюсь на одной странице, и пользователь может нажать на что-то, чтобы удалить отображение всего, кроме таблицы. Это делается путем обертывания съемного материала в div
Когда пользователь делает клик, функция javascript, которая запускается, устанавливает отображение для этого идентификатора «none».
document.getElementById('remove').style.display = 'none';
Второй щелчок восстанавливает дисплей. Щелчок не обязательно должен быть на кнопке. Я использовал его в заголовке отчета, чтобы все исчезло, кроме самого отчета. Вы можете поместить его в одну из своих ячеек таблицы.
В любом случае метод window.print() откроет только окно для принтера; пользователь может затем настроить задание на печать по своему усмотрению, убедиться, что принтер включен и т.д.