在php中的页面中包含动态内容

时间:2016-01-29 20:47:01

标签: php html dompdf

我有以下代码动态加载发票中的项目。我正在寻找一种方法来将多余的项目添加到新页面,依此类推。我想将页面上的项目数限制为设定数量,比如说15个项目。有没有办法在PHP中这样做?下面的代码位于使用dompdf以页面形式出现的文档中

foreach ( $invoice['InvoiceDetail'] as $key=>$item){
        $html .= '<tr style="border-bottom: 1px solid #ccc; line-height: 15px;">';
            $itemNo = isset($item['product_id']) ? $item['product_id'] : '';
            $itemName = isset($item['productName']) ? $item['productName']: '';
            $price = isset($item['price']) ? invoiceNumFormat($item['price']): '';
            $quantity = isset($item['quantity']) ? $item['quantity'] : '';
            $total = invoiceNumFormat( $item['price']*$item['quantity']);

            $html .= '<td style="text-align: left"><h5>'.$itemNo.'</h5></td>';
            $html .= '<td style="text-align: left">'.$itemName.'</td>';
            $html .= '<td style="text-align: left">'.$price.'</td>';
            $html .= '<td style="text-align: left" width="10px">'.$quantity.'</td>';
            $html .= '<td style="text-align: right">'.$total.'</td>';
        $html .= '</tr>';
    }

Dynamic Example

2 个答案:

答案 0 :(得分:1)

对于您的特定情况,您可以指示dompdf打破页面,这有点像:

$itemCount = 0;
foreach ( $invoice['InvoiceDetail'] as $key=>$item){
    $itemCount++;
    $html .= '<tr style="border-bottom: 1px solid #ccc; line-height: 15px;">';

        /* snip */

        if ($itemCount % 20 == 0) {
            $html .= '<tr><td><div style="page-break-before: always;"></div></td></tr>';
        }

        $html .= '<td style="text-align: left"><h5>'.$itemNo.'</h5></td>';
        $html .= '<td style="text-align: left">'.$itemName.'</td>';
        $html .= '<td style="text-align: left">'.$price.'</td>';
        $html .= '<td style="text-align: left" width="10px">'.$quantity.'</td>';
        $html .= '<td style="text-align: right">'.$total.'</td>';

    $html .= '</tr>';
}

Dompdf尚未识别表格行/单元格上的分页符样式。否则,将样式放在那里会更有意义。

答案 1 :(得分:0)

这有帮助吗?

<?php

$per_page = 20;

if ( $pagenum < 2 || !$pagenum ) {
    $limit_start = 0;
} else {
    $limit_start = (( $pagenum -1 ) * $per_page);
}

$sql = "select foo, bar, baz from table where $conditions limit $limit_start, $per_page";
$db->query( $sql ); //or whatever your method is

// while statement to get data into $invoice array

//foreach statement to display it

//pagination links