我在第2页p:dataTable
。左边主要用于选择
<p:dataTable id="leftTable" var="item" value="#{bean.items}"
selection="#{bean.item}" selectionMode="single">
<p:ajax event="rowSelect" update=":rightTable" listener="#{bean.select}"/>
<p:column>
<h:outputText value="#{item.value}" />
</p:column>
</p:dataTable>
这很简单,工作正常。 rightTable 是一个更复杂的例子,这是一个简化的例子:
<p:dataTable id="rightTable" var="row" value="#{bean.rows}">
<p:columns var="col" value="#{bean.cols}">
<h:outputText value="#{bean.map[row.id][col.id]}"/>
</p:columns>
</p:dataTable>
嗯,这也行得很好。现在我实现了composite component
来替换 leftTable 。此组件还具有selection
和select
属性,并且通常也可以使用。调用与p:dataTable
相同的方法,并设置正确的项。
但是,这真是一件令人讨厌的事情:如果我使用自定义组件,始终第一个单元格中的值(第0列,第0行)为{ {1}}。这些值取自null
,我验证了在调用方法后设置特定Map<Long,Map<Long,String>>
的值。
我对这个问题完全无能为力,并且期待回答这个问题真的很难,并且非常感谢有人甚至可以帮助我更详细地调试这个问题。
更新1 :
根据要求,我检查了row.id,col.id
:
#{row.id},#{col.id}
在第一个单元格中, col.id 是错误的。它应该是95,626 | 95,528
96,527 | 96,528
97,527 | 97,528
,但实际为527
(它是前一个请求的值)。为什么会这样?我怎样才能得到正确的值?
更新2 :这是我的组件:
626
这是支持bean:
<composite:interface componentType="my.MenuDmClick">
<composite:attribute name="actionListener" required="true"
method-signature="void listener(javax.faces.event.AjaxBehaviorEvent)"/>
<composite:attribute name="selection"/>
<composite:attribute name="update/>
<composite:attribute name="dm"/>
</composite:interface>
<composite:implementation>
<ui:repeat var="item" value="#{cc.attrs.dm.wrappedData}">
<li>
<p:commandLink actionListener="#{cc.actionListener(item)}"
update="#{cc.attrs.update}">
<h:outputText value="#{item.name}"/>
</p:commandLink>
</li>
</ui:repeat>
</composite:implementation>
答案 0 :(得分:0)
尝试了像
这样的常用内容我遇到了process=@this
......它就像一个魅力!
<c:forEach var="item" items="#{cc.attrs.dm.wrappedData}">
<li>
<p:commandLink process="@this"
actionListener="#{cc.actionListener(item)}" update="#{cc.attrs.update}">
<h:outputText value="#{item.round.name}"/>
</p:commandLink>
</li>
</c:forEach>