PrimeFaces inputText有时无法渲染

时间:2013-12-09 19:23:26

标签: jsf jsf-2 primefaces composite-component

我在这里是因为我在我的应用程序中遇到了一个非常奇怪的问题,如下所示:我有一个带有JSF和EJB的电子商务应用程序,我正在尝试使用用户的信息填写表单。问题是当我有一个已登录的用户时,我的表单显示不好,而且当我没有登录时,他的显示非常好:我正在使用托管bean(MB)进行处理,并且他正在存储一个帐户对象代表用户登录的帐户。我正在使用jsf复合来创建我的表单并模板化xhtml页面。

另外我从glassfish那里得到了这些警告:

  • 警告:无法在视图中找到ID为firstName的组件。
  • 警告:无法在视图中找到ID为lastName的组件。
  • 警告:无法在视图中找到ID街道的组件。
  • 警告:无法在视图中找到ID为postalCode的组件。
  • 警告:无法在视图中找到包含ID城市的组件。

因为它们没有呈现,我用firebug检查了它。

这是我的XHTML页面代码(用户访问的/Form.xhtml):

<ui:composition template="template/common/commonLayout.xhtml"
                xmlns="http://www.w3.org/1999/xhtml"
                xmlns:ui="http://java.sun.com/jsf/facelets"
                xmlns:component="http://java.sun.com/jsf/composite/component">
    <ui:define name="title">Formulaire</ui:define>

    <ui:define name="content">
        <ui:fragment rendered="#{dataManagedBean.connected}">
            <component:FormValidateCartComponent title="Valider mon panier" first_name="yann"  />
        </ui:fragment>
        <ui:fragment rendered="#{not dataManagedBean.connected}">
            <component:FormValidateCartComponent title="Valider mon panier" first_name="NoName"  />
        </ui:fragment>
    </ui:define>
</ui:composition>

这是我的表单组件:

<?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"
      xmlns:ui="http://java.sun.com/jsf/facelets">
    <composite:interface>
        <composite:attribute name="title" />
        <composite:attribute name="first_name"/>
        <!--ajouter des attributs pour le cas ou l'utilisateur est connecté -->
    </composite:interface>
    <composite:implementation>
        <h:form id="form" class="span5 offset4">
            <h2>#{cc.attrs.title}</h2>
            <p:panel header="Adresse de Livraison">  
                <h:panelGrid id="gridpanel" columns="2" style="margin-bottom:10px">  
                    <h:outputLabel for="firstName" value="Prenom : " />  
                    <p:inputText id="firstName" value="#{cc.attrs.first_name}" binding="#{firstName}"/>
                    <h:outputLabel for="lastName" value="Nom : " />  
                    <p:inputText id="lastName" binding="#{lastName}"/>
                    <h:outputLabel for="street" value="Rue : " />  
                    <p:inputText id="street" binding="#{street}" />
                    <h:outputLabel for="postalCode" value="Code Postale : " />  
                    <p:inputText id="postalCode" binding="#{postalCode}" />
                    <h:outputLabel for="city" value="Ville : "/>  
                    <p:inputText id="city"  binding="#{city}"/>
                    <h:outputLabel for="pbutton"/>  
                    <h:commandButton id="pbutton" class="paypal-button" 
                                     action="Cart.xhtml" 
                                     actionListener="#{dataManagedBean.creatOrder(firstName.value,lastName.value,street.value,postalCode.value,city.value)}" /> 
                </h:panelGrid>  
            </p:panel> 
            <ui:fragment rendered="#{!dataManagedBean.connected}">
                <p:panel header="Connexion">  
                    <h:panelGrid id="grid" columns="2" style="margin-bottom:10px">
                        <h:outputLabel for="login" value="Login : "/>  
                        <p:inputText id="login" binding="#{login}" />
                        <h:outputLabel for="password" value="Mot de passe : "/>  
                        <p:inputText id="password" binding="#{password}" />
                        <h:outputLabel for="accountCreationButton"/>  
                        <h:commandButton id="accountCreationButton" value="Créer un compte" action="Cart.xhtml" actionListener="#{dataManagedBean.createAccount(login.value,password.value,dataManagedBean.creatOrder(firstName.value,lastName.value,street.value,postalCode.value,city.value))}"/>
                    </h:panelGrid>
                </p:panel>
            </ui:fragment>
        </h:form>  
    </composite:implementation>
</html>

目前我只是尝试设置first_name,但之前我记录时所说的html渲染中缺少每个inputText。这怎么可能 ?当我断开连接并访问表单时一切正常...感谢帮助我真的不知道为什么会发生这种情况...我的连接和断开功能只是通过JPA请求帐户登录和密码并断开连接只需在托管bean中将帐户设置为null即可。

编辑:使用c:如果我的问题解决了!为什么,我不知道......如果你有线索,请告诉我:)。

Managed Bean部分代码:

    public void connect(String login, String password) {
        account = client.connect(login, password);
    }

    public String disconnect() {
        if (account != null) {
            account = null;
        }
        return "index.xhtml?faces-redirect=true";
    }

    public boolean isConnected() {
        return account != null;
    }

1 个答案:

答案 0 :(得分:0)

UI片段导致视图范围和一些属性的一些麻烦,我sugest只需更改ui:frament with ah:panelGroup,如果你只是把渲染属性JSF不会生成span也不会生成div,只会渲染或不渲染内部内容 编辑: 看起来像balusC说,ui:fagment将无法解决问题,快速阅读后我找不到错误,你使用的范围是什么?,它是CDI托管bean还是老面孔bean?