p:tree ajax事件正在更新其他组件

时间:2013-11-13 10:46:33

标签: ajax jsf primefaces tree spring-webflow

我对p:tree组件

的ajax事件有疑问

这是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事件重新渲染上面的面板?

0 个答案:

没有答案