如何在Bootsfaces数据表中实现复杂的头文件

时间:2017-05-26 20:07:14

标签: jsf datatable datatables bootsfaces

我正在使用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>
  ...

1 个答案:

答案 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>