HTML2PDF Содержимое таблицы выходит за пределы страницы

Я использую библиотеку HTML2PDF и у меня возникает проблема, когда я пытаюсь вывести свой PDF. На самом деле, моя таблица всегда обрезана, и не может отображать все содержимое таблицы без ее обрезки. Я определил стиль css, но, похоже, это должно сработать. Более того, если я не определил свой скрипт php в таблице операторов echo border="1px", он не принимает стиль css, определенный ранее.

Вот мой код:

<!DOCTYPE html>
<html>
<head>
<title>Test PDF</test>
<style>
table{width:100%; border-collapse:collapse; table-layout:auto; vertical-align:top; margin-bottom:15px; border:1px solid #CCCCCC;}
table thead th{font-size: 2px; color:#FFFFFF; background-color:#666666; border:1px solid #CCCCCC; border-collapse:collapse; text-align:center; table-layout:auto; vertical-align:middle;}
table tbody td{vertical-align:top; border-collapse:collapse; border-left:1px solid #CCCCCC; border-right:1px solid #CCCCCC; font-size: 2px;}
table thead th, table tbody td{padding:5px; border-collapse:collapse;}
table tbody tr.light{color:#979797; background-color:#F7F7F7;}
table tbody tr.dark{color:#979797; background-color:#E8E8E8;}
</style>
</head>
<body>
<html>
<?php
require_once "config.php";

//Start html2pdpf session
ob_start();
//Get tablename
$tablename=$_POST["tablename"];
$ShowPivotTableResult='SELECT * FROM '.$tablename.'';
    $resultLeast=mysqli_query($conn,$ShowPivotTableResult) or die(mysqli_error($conn));
if (!$resultLeast) {
    die("Query to show fields from table failed");
    }
//Display Pivot Table content - script
$fields_num = mysqli_num_fields($resultLeast);
    echo "<table border='1px' CELLSPACING='0' cellpadding='2'><thead><tr>";
    // printing table headers
for($i=0; $i<$fields_num; $i++)
{
    $field = mysqli_fetch_fields($resultLeast);
    echo '<th>'.$field[$i]->name.'</th>';
}
echo "</tr></thead><tbody>\n";
// printing table rows
while($rowLEAST = mysqli_fetch_row($resultLeast))
{
    echo "<tr>";
    // $row is array... foreach( .. ) puts every element
    // of $row to $cell variable
    foreach($rowLEAST as $cellPIVOT)
    echo "<td>$cellPIVOT</td>";
    echo "</tr>\n";
    }
    echo '</tbody></table><br/><br/>';

$content = ob_get_clean();

    // convert
    require_once('html2pdf.class.php');
    try
    {
        $html2pdf = new HTML2PDF('L', 'A4', 'fr', true, 'UTF-8', 0);
        $html2pdf->pdf->SetDisplayMode('fullpage');
        $html2pdf->writeHTML($content, isset($_GET['vuehtml']));
        ob_end_clean();
        $html2pdf->Output(''.$tablename.'.pdf');
    }
    catch(HTML2PDF_exception $e) {
        echo $e;
        exit;
    }

mysqli_close($conn);
?>
</body>
</html>

3 ответа

Решение

Попробуйте использовать абсолютную длину в ширину таблицы, например, pt. A4 имеет ширину 595pt. О атрибуте css, попробуйте использовать класс вместо тега. пример:

HTML

<style>
    .tbl{
     width: 595pt;
     border: 1px solid #000;
    }
</style>

PHP

echo "<table class='tbl' CELLSPACING='0' cellpadding='2'><thead><tr>";

Я решил перенос слов в TD, поместив DIV внутри TD со стилем переноса слов и установив ширину таблицы. Эти две вещи вместе сработали. Например

      table {
  width: 295pt;
}

<td>
  <div style="word-wrap: break-word;">Some long html posibly-joined-text-that-will-overflow-off-of-the-page</div>
</td>

Изменить: иногда это работает, а иногда нет. В итоге я перешел на dompdf, и это решило все мои проблемы.

Если вы указали ширину ячейки таблицы в процентах, попробуйте удалить ее и контролировать ширину с помощью атрибута style. Ширина должна быть в мм и пропорциональна ширине страницы.

Например, если ваша страница А4 - портретная ширина 595,276. Ваша 50% ширина ячейки таблицы займет (595.276/2) ширину поля в атрибуте стиля.

Другие вопросы по тегам