我对p:tree
组件
这是xhtml代码:
<form id="form1">
<!-- Other components -->
<p:panel id="panel1" binding="#{panel1}"
header="..." toggleable="true" toggleSpeed="500"
collapsed="false" dynamic="true"
rendered="#{service.checkMethod(...)}">
<div class="column">
<p:tree id="treeId" value="#{tree.root}"
var="node" selectionMode="single"
rendered="#{tree != null}"
selection="#{flowScope.selectedNode}"
widgetVar="treeId"
process="tree">
<p:ajax event="select" process="@this"
update="@this :#{anotherPanel.clientId} :#{anotherPanel2.clientId}"
listener="#{service.onNodeSelect}" oncomplete="setSelectedNode()" />
<p:ajax event="expand" process="@this" listener="#{service.onNodeExpand}" />
<p:ajax event="collapse" process="@this" listener="#{service.onNodeCollapse}" />
<p:treeNode>
<h:outputLabel value="#{node.attribute}" />
</p:treeNode>
</p:tree>
<h:outputLabel
value="Empty"
rendered="#{tree.isEmpty()}" />
</div>
</p:panel>
<!-- Other components -->
</form>
panel1呈现属性有一个方法,每次更新时都会创建一个新树,但不知何故,树上的所有ajax事件都在调用该方法。即使是没有定义更新的扩展和折叠更新也是如此。
我已经尝试在所有ajax事件上使用不同类型的更新和处理global="false", immediate="true"
,或者在树和面板之间放置其他面板,但它具有相同的效果。我用Eclipse搜索了我的所有文件,以确保这个方法不会在别处调用,但它只在这里使用。
有没有办法阻止树ajax事件重新渲染上面的面板?