以编程方式加载的复合在回发后消失元素



在我的项目中,我正在以编程方式向一个primefaces p:面板添加一个复合组件,如下所述:如何在JSF 2中以编程方式或动态地创建一个复合组件。

这是复合组件:

<?xml version="1.0" encoding="UTF-8"?>
<!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:composite="http://java.sun.com/jsf/composite"
   xmlns:p="http://primefaces.org/ui">
<composite:interface>
</composite:interface>
<composite:implementation>
   <h:panelGroup styleClass="ui-grid ui-grid-responsive"
    id="myPG" layout="block">
       <div class="ui-grid ui-grid-responsive label-777777">
        <div class="ui-grid-row">
            <div class="ui-grid-col-11-5">
                <label>#{msgs['label.content']}</label>
            </div>
        </div>
    </div>

    <p:commandButton styleClass="myButton blueButton"
        id="myCompositeButton" value="#{msgs['button.elimina']}"
        update="@form"
        actionListener="#{myController.onMyClick}" />
  </h:panelGroup>
</composite:implementation>
</html>

当添加到页面时,它显示良好,但在回发按钮后,"div"部分消失了(它没有发送到浏览器)。

如果我使用h:panelGroup和h:outputlabel实现div,则元素呈现为空(#{msgs['label. p])。

下面是onMyClick处理程序(其中没有逻辑):
public void onMyClick()
{
    System.out.println("#########################################CALLBAK");
}

我错在哪里?

Primefaces版本是5.1,运行在JBoss AS 7.1.1上

由于我在以编程方式在目标体系结构(IBM was 8.5,带有myfaces 2.0,不,我不能更改jsf实现)上创建组件时遇到问题,我改变了方法,在h:panelGroup中使用支持bean绑定ui:include

<h:panelGroup id="myPanel" layout="block" rendered="#{myController.moduleSelected }">
   <ui:include src="#{myController.moduleType}"></ui:include>
</h:panelGroup>

发布答案以帮助其他用户

最新更新