DomPDF表固定列宽并打破长文

时间:2017-11-27 09:12:58

标签: php html pdf dompdf

我有一个非常长的文本表,没有空格(用户希望发布一个完整的网站网址,包含所有参数)

然后我在每个word-break:break-all;上设置word-wrap:break-word;<td>,希望文本可以放在桌面上。

我还将所有<td> /列宽设置为指定的数量。

我在这里使用Laravel的DomPDF包装:https://github.com/barryvdh/laravel-dompdf

案例1:table-layout: fixed

<table class="bordered">
    <tr class="font-12">
        <th style="width: 25px">No</th>
        <th style="width: 100px">Nama Alat</th>
        <th style="width: 25px">Jml</th>
        <th style="width: 300px">Spesifikasi</th>
        <th style="width: 300px">Supplier</th>
        <th style="width: 150px">Gambar</th>
    </tr>
    @foreach ($items as $index => $item)
    <tr>
        <td style="width: 25px">{{ ($index+1) }}</td>
        <td style="width: 100px">{{ $item['name'] }}</td>
        <td style="width: 25px">{{ $item['jumlah_disetujui'] }}</td>
        <td class="font-12" style="width: 300px; word-break:break-all; word-wrap:break-word;">
            {!! nl2br( $item['spesifikasi'] ) !!}
        </td>
        <td class="font-12" style="width: 300px; word-break:break-all; word-wrap:break-word;">
            {!! nl2br( $item['supplier'] ) !!}
        </td>
        <td style="width: 150px">
            @if ($item['image'])
                <img style="max-height: 125px;" src="{{ $item['image'] }}" />
            @else
                -
            @endif
        </td>
    </tr>
    @endforeach
</table>

案例1 PDF结果:自动换行不起作用,列宽适用于文本较少的单元格,但对于具有长文本的单元格(需要自动换行)不起作用。< / p>

Word-wrap does not work

案例2 :添加table-layout: fixed

<table class="bordered" style="table-layout: fixed"> <!-- only added this -->
    <tr class="font-12">
        <th style="width: 25px">No</th>
        <th style="width: 100px">Nama Alat</th>
        <th style="width: 25px">Jml</th>
        <th style="width: 300px">Spesifikasi</th>
        <th style="width: 300px">Supplier</th>
        <th style="width: 150px">Gambar</th>
    </tr>
    @foreach ($items as $index => $item)
    <tr>
        <td style="width: 25px">{{ ($index+1) }}</td>
        <td style="width: 100px">{{ $item['name'] }}</td>
        <td style="width: 25px">{{ $item['jumlah_disetujui'] }}</td>
        <td class="font-12" style="width: 300px; word-break:break-all; word-wrap:break-word;">
            {!! nl2br( $item['spesifikasi'] ) !!}
        </td>
        <td class="font-12" style="width: 300px; word-break:break-all; word-wrap:break-word;">
            {!! nl2br( $item['supplier'] ) !!}
        </td>
        <td style="width: 150px">
            @if ($item['image'])
                <img style="max-height: 125px;" src="{{ $item['image'] }}" />
            @else
                -
            @endif
        </td>
    </tr>
    @endforeach
</table>

案例2 PDF结果:自动换行有效,但列宽无效

Word-wrap works, but column width has no effect

我想要的是:具有固定宽度列的表格,其中包含有效的自动换行

这对DomPDF不可能吗?
任何变通方法或者“黑客攻击”。那有助于实现这一目标吗?

或许我应该开始寻找其他/更好的PDF生成器?

编辑:
我也发现了很多Github问题,没有修复错误的迹象

3 个答案:

答案 0 :(得分:4)

我使用table-layout:fixed将宽度设置为%,并且效果很好

答案 1 :(得分:1)

不是真正的“回答”,但我的解决方案是切换到Snappy PDF(使用了Laravel Package)。 像魅力一样工作,我甚至没有改变HTML标记。

答案 2 :(得分:0)

我遇到了同样的问题,由于@Solonka的回答,我得以解决。

示例:

<table border="1px" style="table-layout:fixed;">
    <tr>
        <th style="width:5%;">5%</th>
        <th style="width:10%;">10%</th>
        <th style="width:25%;">25%</th>
        <th style="width:60%;">60%</th>
    </tr>
</table>