php – DomPDF表固定列宽并打破长文本
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了php – DomPDF表固定列宽并打破长文本,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2698字,纯文字阅读大概需要4分钟。
内容图文
![php – DomPDF表固定列宽并打破长文本](/upload/InfoBanner/zyjiaocheng/811/dc8aacc6e9004d6a838f1971c3c12145.jpg)
我有一个非常长的文本表没有空格(用户希望发布一个完整的网站URL与所有参数)
然后我开始讲话:打破一切;和自动换行:break-word;在每个< td>上希望文本可以放在桌面上.
我还设置了所有< td> /列宽到某个指定的数量.
我在这里使用Laravel的DomPDF包装器:https://github.com/barryvdh/laravel-dompdf
案例1:没有表格布局:固定
<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结果:自动换行不起作用,列宽适用于文本较少的单元格,但对于具有长文本的单元格(需要自动换行)不起作用.
案例2:添加表格布局:已修复
<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结果:自动换行有效,但列宽无效
我想要的是:一个固定宽度列的表,具有工作自动换行
这对DomPDF来说不可能吗?
任何可以帮助实现此目的的解决方法或“黑客”?
或许我应该开始寻找其他/更好的PDF生成器?
编辑:
我也发现了很多Github问题,没有修复bug的迹象
> Table cell width is not honored if content exceeds the specified dimensions #1017
> Table widths do not conform to css width attribute. #1253
> Fixed table layout ignored column widths #1432
解决方法:
我用table-layout设置宽度%:固定,它工作正常
内容总结
以上是互联网集市为您收集整理的php – DomPDF表固定列宽并打破长文本全部内容,希望文章能够帮你解决php – DomPDF表固定列宽并打破长文本所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。