我正在使用Bootsfaces数据表来显示我的数据。但是,我想实现复杂的标题,如下所示:https://datatables.net/examples/basic_init/complex_header.html
我尝试在第一个dataTableColumn中的标题facet下直接添加<th rowspan>
和<th colspan>
,但顶部有一个丑陋的空行。
我还尝试在<b:dataTable...>
标记之前添加整个标题构面,在<b:dataTableColumn>
之前,但该标题代码不会生成到html中。还有其他建议吗?我不想切换到primefaces或richfaces作为我修复的框架。
我尝试实现复杂标题的代码如下所示:
<b:dataTable value="#{podStatusListBean.podStatusBeanList}"
var="podStatus"
id="podStatuses">
<b:dataTableColumn footer-style='background-color:orange'
footer-styleclass="{podStatusListBean.footerVisibility}">
<f:facet name="header">
<tr>
<th rowspan="2">Name</th>
<th colspan="2">HR Information</th>
<th colspan="3">Contact</th>
</tr>
</f:facet>
...
答案 0 :(得分:0)
这是我们在下一个BootsFaces版本中添加的新功能(可能是1.2)。截至2017年6月15日,当前版本的BootsFaces 1.1.1仅支持每列复杂的标题。
每列复杂标题(自BootsFaces 0.8.0起支持):
添加标题构面到<b:dataTableColumn />
,几乎就像您尝试的那样。但请记住,BootsFaces已生成<tr>
和<th>
标记,因此您可以再次嵌套它们。但你可以这样做:
<b:dataTableColumn>
<f:facet name="header">
<ul
style="margin-bottom: 0; list-style-type: none; padding-left: 0">
<li>Price</li>
<li>Engine Power</li>
</ul>
</f:facet>
€ #{car.price}
<br />
#{car.enginePowerKW} KW (#{car.enginePower} hp)
</b:dataTableColumn>
</b:dataTable>
更复杂的标头(从BootsFaces 1.2.0开始支持):
向周围的<b:dataTable />
标记添加标题构面。在这种情况下,您负责定义正确数量的表头。如果你跳过一个,你会得到一个JavaScript错误奖励。在许多情况下,它甚至会被忽视,但数据表的初始化是不完整的,所以你要小心。
<b:dataTable value="#{carPool.carPool}"
var="car"
page-length="5"
page-length-menu="5,10,20">
<f:facet name="header">
<tr>
<th rowspan="2">Car</th>
<th colspan="2">Appearance</th>
<th colspan="2">Technical Data</th>
</tr>
<tr>
<th>Color</th>
<th>Year</th>
<th>Price</th>
<th>Power</th>
</tr>
</f:facet>
<b:dataTableColumn>
#{car.brand} #{car.type}
</b:dataTableColumn>
<b:dataTableColumn value="#{car.color}" />
<b:dataTableColumn value="#{car.year}" order="asc" />
<b:dataTableColumn value="#{car.price}" />
<b:dataTableColumn value="#{car.enginePower}"/>
</b:dataTable>