Php DOMPDFModule赢得';无法正确渲染字段

Php DOMPDFModule赢得';无法正确渲染字段,php,zend-framework2,Php,Zend Framework2,我正在尝试通过Zend Framework 2的DOMPDFModule呈现PDF文档。它在大多数情况下渲染成功,但字段处于关闭状态。以下是我的控制器和视图代码: public function pdfAction() { $pdf = new PdfModel(); $pdf->setOption('filename', 'questions'); $pdf->setOption('paperSize', 'a3'); $pdf->setO

我正在尝试通过Zend Framework 2的DOMPDFModule呈现PDF文档。它在大多数情况下渲染成功,但字段处于关闭状态。以下是我的控制器和视图代码:

 public function pdfAction()
 {
    $pdf = new PdfModel();
    $pdf->setOption('filename', 'questions');
    $pdf->setOption('paperSize', 'a3');
    $pdf->setOption('paperOrientation', 'landscape');

    $pdf->setVariables(array(
        'records' => $this->getQuestionsService()->getRecords()
    ));

    return $pdf;
 }
以及以下意见—

  <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/css/bootstrap.min.css" type="text/css">

<div class="container">
    <div class="row">
        <div class="col-md-6">
            <img src="http://dev.teeforall.com/images/logo.png">
        </div>

        <div class="col-md-6">
            <h1>Questions Report</h1>
        </div>
    </div>
</div>


    <table class="table table-striped table-hover table-bordered">
            <tr>
                <td>Id</td> <!-- 0 -->
                <td>Question</td> <!-- 1 -->
                <td style="white-space: nowrap;">Order Issue</td> <!-- 2 -->
                <td style="white-space: nowrap;">Shipping Issue</td> <!-- 3 -->
                <td style="white-space: nowrap;">Refunds/Returns Issues</td><!-- 4 -->
                <td style="white-space: nowrap;">Update Issues</td> <!-- 5 -->
                <td style="white-space: nowrap;">Campaign Issue</td> <!-- 6 -->
                <td style="white-space: nowrap;">Change Issues</td> <!-- 7 -->
                <td style="white-space: nowrap;">Design Issues</td> <!-- 8 -->
                <td style="white-space: nowrap;">TeeForAll Works</td> <!-- 9 -->
                <td style="white-space: nowrap;">Order ID</td> <!-- 10 -->
                <td style="white-space: nowrap;">Site url</td> <!-- 11 -->
                <td>Name</td> <!-- 12 -->
                <td>Email</td> <!-- 13 -->
                <td>Comment</td> <!-- 14 -->
                <td>Status</td> <!-- 15 -->
            </tr>

            <?php 


                if (false !== $this->records) {
                    foreach ($this->records as $records): ?>

                    <tr>
                        <td><?php echo $records->id; ?></td> <!--  0 -->
                        <td><?php echo $records->question; ?></td> <!-- 1 -->
                        <td><?php echo $records->order_issue; ?></td> <!-- 2 -->
                        <td><?php echo $records->sub_shipping_issue; ?></td> <!-- 3 -->
                        <td><?php echo $records->sub_refunds_returns_issue; ?></td> <!-- 4 -->
                        <td><?php echo $records->sub_update_issue; ?></td> <!-- 5 -->
                        <td><?php echo $records->sub_campaign_issue; ?></td> <!-- 6 -->
                        <td><?php echo $records->sub_campaign_change_issues; ?></td> <!-- 7 -->
                        <td><?php echo $records->sub_campaign_design_changes; ?></td> <!-- 8 -->
                        <td><?php echo $records->sub_teeforall_works; ?></td> <!-- 9 -->
                        <td><?php echo $records->order_id; ?></td> <!-- 10 -->
                        <td><?php echo $records->site_url; ?></td> <!-- 11 -->
                        <td><?php echo $records->name; ?></td> <!-- 12 -->
                        <td><?php echo $records->email; ?></td> <!-- 13 -->
                        <td><?php echo $records->comment; ?></td> <!-- 14 -->
                        <td><?php echo $records->status; ?></td> <!-- 15 -->
                    </tr>
                <?php endforeach; ?>

                <?php } else {  ?>

                    <tr>
                        <td>null</td>
                        <td>null</td>
                        <td>null</td>
                        <td>null</td>
                        <td>null</td>
                        <td>null</td>
                        <td>null</td>
                        <td>null</td>
                        <td>null</td>
                        <td>null</td>
                        <td>null</td>
                        <td>null</td>
                        <td>null</td>
                        <td>null</td>
                        <td>null</td>
                        <td>null</td>
                    </tr>
                <?php 
                      }
                ?>
    </table>
另外,这张图片可能最能描述我想说的话:

如您所见,字段被关闭了1(id字段中应该有15个),以此类推

任何帮助都将不胜感激


谢谢

代码看起来不错,但大部分pdf库在使用CSS时效果不太好

首先尝试使用不带css的表格呈现pdf

看看DOMPDF是否可以毫无问题地渲染它

<table>
        <tr>
            <td>Id</td> <!-- 0 -->
            <td>Question</td> <!-- 1 -->
            <td style="white-space: nowrap;">Order Issue</td> <!-- 2 -->
            <td style="white-space: nowrap;">Shipping Issue</td> <!-- 3 -->
            <td style="white-space: nowrap;">Refunds/Returns Issues</td><!-- 4 -->
            <td style="white-space: nowrap;">Update Issues</td> <!-- 5 -->
            <td style="white-space: nowrap;">Campaign Issue</td> <!-- 6 -->
            <td style="white-space: nowrap;">Change Issues</td> <!-- 7 -->
            <td style="white-space: nowrap;">Design Issues</td> <!-- 8 -->
            <td style="white-space: nowrap;">TeeForAll Works</td> <!-- 9 -->
            <td style="white-space: nowrap;">Order ID</td> <!-- 10 -->
            <td style="white-space: nowrap;">Site url</td> <!-- 11 -->
            <td>Name</td> <!-- 12 -->
            <td>Email</td> <!-- 13 -->
            <td>Comment</td> <!-- 14 -->
            <td>Status</td> <!-- 15 -->
        </tr>

         <tr>
            <td>Data 0</td> <!-- 0 -->
            <td>Data 1</td> <!-- 1 -->
            <td>Data 2</td> <!-- 2 -->
            <td>Data 3</td> <!-- 3 -->
            <td>Data 4</td><!-- 4 -->
            <td>Data 5</td> <!-- 5 -->
            <td>Data 6</td> <!-- 6 -->
            <td>Data 7</td> <!-- 7 -->
            <td>Data 8</td> <!-- 8 -->
            <td>Data 9</td> <!-- 9 -->
            <td>Data 10</td> <!-- 10 -->
            <td>Data 11</td> <!-- 11 -->
            <td>Data 12</td> <!-- 12 -->
            <td>Data 13</td> <!-- 13 -->
            <td>Data 14</td> <!-- 14 -->
            <td>Data 15</td> <!-- 15 -->
        </tr>

</table>          

身份证件
问题:
订单发行
航运问题
退款/退货问题
更新问题
竞选议题
改变问题
设计问题
蒂福尔工厂
订单号
站点url
名称
电子邮件
评论
地位
数据0
数据1
数据2
数据3
数据4
数据5
数据6
数据7
数据8
数据9
数据10
数据11
数据12
数据13
数据14
数据15

问题是由
https://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/css/bootstrap.min.css
从视图调用的。 准确地说,
*:before,*:after
导致该行移位

这是DOMPDF中的一个已知问题:

作为临时解决方案,您可以尝试在css:下面添加下一个代码,或者使用bootstrap.min.css的修改版本。这是您应该制作的版本:

* {
-webkit框大小:边框框;
-moz框大小:边框框;
框大小:边框框
}
//删除接下来的6行
:之后,
:之前{
-webkit框大小:边框框;
-moz框大小:边框框;
框大小:边框框
}
一旦DOMPDF团队修复了此错误,请确保您没有忘记:

Dompdf对格式不良的HTML输入不是特别宽容。到 避免任何意外的渲染问题您应该启用 运行时内置HTML5解析器 ($dompdf->set_选项('isHtml5ParserEnabled',true);)或运行HTML 通过HTML验证程序/清理程序(如Tidy或W3C标记 验证服务)

不过,您可能也对DOMPDFModule有顾虑,因为它需要0.6.*版本的
dompdf
,但是
isHtml5ParserEnabled
仅在v0.7.0-beta3中可用。

为什么不在项目中直接使用DOMPDF类呢?这是一个为简化而开发的模块。请参见此处-可能是print_r的数据检查问题($this->getQuestionsService()->getRecords())它是有效的,只是检查过了。它在常规视图模型中呈现良好。只需在他们的github存储库中提出一个问题,构建器就可以为您提供跟踪。
<table>
        <tr>
            <td>Id</td> <!-- 0 -->
            <td>Question</td> <!-- 1 -->
            <td style="white-space: nowrap;">Order Issue</td> <!-- 2 -->
            <td style="white-space: nowrap;">Shipping Issue</td> <!-- 3 -->
            <td style="white-space: nowrap;">Refunds/Returns Issues</td><!-- 4 -->
            <td style="white-space: nowrap;">Update Issues</td> <!-- 5 -->
            <td style="white-space: nowrap;">Campaign Issue</td> <!-- 6 -->
            <td style="white-space: nowrap;">Change Issues</td> <!-- 7 -->
            <td style="white-space: nowrap;">Design Issues</td> <!-- 8 -->
            <td style="white-space: nowrap;">TeeForAll Works</td> <!-- 9 -->
            <td style="white-space: nowrap;">Order ID</td> <!-- 10 -->
            <td style="white-space: nowrap;">Site url</td> <!-- 11 -->
            <td>Name</td> <!-- 12 -->
            <td>Email</td> <!-- 13 -->
            <td>Comment</td> <!-- 14 -->
            <td>Status</td> <!-- 15 -->
        </tr>

         <tr>
            <td>Data 0</td> <!-- 0 -->
            <td>Data 1</td> <!-- 1 -->
            <td>Data 2</td> <!-- 2 -->
            <td>Data 3</td> <!-- 3 -->
            <td>Data 4</td><!-- 4 -->
            <td>Data 5</td> <!-- 5 -->
            <td>Data 6</td> <!-- 6 -->
            <td>Data 7</td> <!-- 7 -->
            <td>Data 8</td> <!-- 8 -->
            <td>Data 9</td> <!-- 9 -->
            <td>Data 10</td> <!-- 10 -->
            <td>Data 11</td> <!-- 11 -->
            <td>Data 12</td> <!-- 12 -->
            <td>Data 13</td> <!-- 13 -->
            <td>Data 14</td> <!-- 14 -->
            <td>Data 15</td> <!-- 15 -->
        </tr>

</table>