Jsf 在复合组件内部创建DataScroller时出错

Jsf 在复合组件内部创建DataScroller时出错,jsf,jsf-2,composite-component,Jsf,Jsf 2,Composite Component,我有一个内置dataScroller的复合组件(tomahawk)。在我的xhtml中,我尝试使用此组件,但收到一个错误: java.lang.IllegalArgumentException:找不到属性引用的UIDatadataScroller@for='myTable' 组成部分: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-

我有一个内置dataScroller的复合组件(tomahawk)。在我的xhtml中,我尝试使用此组件,但收到一个错误:

java.lang.IllegalArgumentException:找不到属性引用的UIDatadataScroller@for='myTable'

组成部分:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml"
    xmlns:h="http://java.sun.com/jsf/html"
    xmlns:f="http://java.sun.com/jsf/core"
    xmlns:ui="http://java.sun.com/jsf/facelets"
    xmlns:composite="http://java.sun.com/jsf/composite"
    xmlns:t="http://myfaces.apache.org/tomahawk">
<composite:interface>
    <composite:attribute name="for" targets="scroll"></composite:attribute>
    <composite:attribute name="paginatorMaxPages" />
</composite:interface>

<h:head>
</h:head>
<h:body>
    <composite:implementation>

        <div class="paginacao">
            <t:dataScroller id="scroll" for="#{cc.attrs.for}"
                styleClass="paginador" renderFacetsIfSinglePage="false"
                pageIndexVar="numeroPagina" pageCountVar="quantidadePaginas"
                rowsCountVar="quantidadeRegistros" paginator="true"
                paginatorMaxPages="#{cc.attrs.paginatorMaxPages}"
                paginatorTableClass="paginasPaginador"
                paginatorActiveColumnClass="negrito">

                <f:facet name="first">#{labels['paginacao.primeira']}</f:facet>
                <f:facet name="previous">#{labels['paginacao.anterior']}</f:facet>
                <f:facet name="next">#{labels['paginacao.proxima']}</f:facet>
                <f:facet name="last">#{labels['paginacao.ultima']}</f:facet>
            </t:dataScroller>
        </div>

    </composite:implementation>
</h:body>
</html>

#{标签['paginacao.primeira']}
#{标签['paginacao.front']}
#{标签['paginacao.proxima']}
#{标签['paginacao.ultima']}
我的数据表:

<h:form>
 ...
    <t:dataTable id="myTable" var="item" value="#{mBean.lista}">
 ...
    </t:dataTable>
 ...
</h:form>       

<param:parametrosScroll id="dataScroller" for="myTable" paginatorMaxPages="5" />

...
...
...

为了确保同一视图中多个实例的可重用性,复合组件本质上是命名容器,如
等。在您的特定情况下,将在
的上下文中搜索
for=“myTable”
中的相对客户端ID,但没有这样的组件。相反,它在组合之外,在另一个命名容器中,由
表示

您有两种选择:

  • 在给
    一个固定ID后,传递一个绝对客户端ID

    for=":myForm:myTable"
    

  • 我用了一个标记文件。谢谢