IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

JSF Java Discussion :

[Primefaces 6.2] attribut rendered


Sujet :

JSF Java

  1. #1
    Membre actif Avatar de Elwe31
    Profil pro
    Inscrit en
    Octobre 2004
    Messages
    487
    Détails du profil
    Informations personnelles :
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Octobre 2004
    Messages : 487
    Points : 220
    Points
    220
    Par défaut [Primefaces 6.2] attribut rendered
    Bonjour,

    Je bloque sur un truc qui me semble tout simple.
    dans ma page, je saisi la date de naissance, et l'age devrait apparaître a coté du champs.
    L'age n’apparaît pas.
    si j’enlève le rendered, l'age est bien mise a jour dans la page ?

    dans ma page :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    <p:column>
    	<p:inputMask  id="datePatient" value="#{frmCalcul.dateParesonne}" size="8" mask="99/99/9999">
    		<p:ajax event="blur" update="idAge" listener="#{frmCalcul.calculAgeEvent}" />
    	</p:inputMask>
    </p:column>
     
    <p:column><p:outputLabel  id="idAge" value=" #{frmCalcul.age} #{msg['form.info.ans']}" rendered="#{frmCalcul.age>0}"/></p:column>
    j'ai essayé ça, c'est pareil
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    rendered="#{frmCalcul.age!=0}"
    merci
    - La communication consiste a comprendre celui qui ecoute !
    - Qui veut faire quelquechose trouve un moyen, qui ne veut rien faire trouve une excuse

  2. #2
    Membre expérimenté Avatar de Cincinnatus
    Homme Profil pro
    Développeur d'applications métier
    Inscrit en
    Mars 2007
    Messages
    592
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Développeur d'applications métier
    Secteur : Service public

    Informations forums :
    Inscription : Mars 2007
    Messages : 592
    Points : 1 679
    Points
    1 679
    Par défaut
    Bonjour,

    Le problème dans le cas où un composant Primefaces n'est pas créé (rendered) lors de la génération de la page, c'est que l'update ne peut pas agir dessus.
    Il faut utiliser un composant père (ex : une table, une div...) qui peut être mis à jour et générer dans son contenu le composant à ajouter.

    Ici, le <p:column> peut servir de conteneur(à vérifier, selon la hiérarchie des composants Primefaces). Et le outputLabel sera généré selon la valeur de son attribut rendered lors de l'update du conteneur.

  3. #3
    Membre chevronné Avatar de jeffray03
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Juillet 2008
    Messages
    1 501
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Allemagne

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Juillet 2008
    Messages : 1 501
    Points : 2 120
    Points
    2 120
    Par défaut
    salut,
    je confirme les propos de Cincinnatus car ,
    Il est impossible de rendre (mettre à jour) un composant avec ajax si le composant lui-même n'est pas rendu en premier lieu. Le composant doit toujours être rendu avant que ajax puisse le restituer. Ajax utilise JavaScript document.getElementById () pour rechercher le composant à mettre à jour. Mais si JSF n'a pas restitué le composant en premier lieu, alors JavaScript ne trouve rien à mettre à jour.

    Un exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    <h:panelGrid columns="3" cellpadding="5">
               <p:outputLabel for="date" value="Date: " />
               <p:inputMask id="date" value="#{frmCalcul.date}" mask="99/99/9999">
                  <p:ajax event="blur" update="text" listener="#{frmCalcul.calculAgeEvent}" />
               </p:inputMask> 
               <h:panelGroup id="text">
                 <p:outputLabel  id="idAge" value=" #{frmCalcul.age} " rendered="#{frmCalcul.age>0}"/>
               </h:panelGroup>
            </h:panelGrid>
    Eric

  4. #4
    Membre actif Avatar de Elwe31
    Profil pro
    Inscrit en
    Octobre 2004
    Messages
    487
    Détails du profil
    Informations personnelles :
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Octobre 2004
    Messages : 487
    Points : 220
    Points
    220
    Par défaut
    Ok, merci la notion de renderer est plus clair maintenant.
    Pour info, ça ne fonctionne pas mais la solution de jeffray03 est nickel
    encore merci a vous 2
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    <p:column id = "colIdAge" >
    - La communication consiste a comprendre celui qui ecoute !
    - Qui veut faire quelquechose trouve un moyen, qui ne veut rien faire trouve une excuse

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 13
    Dernier message: 11/05/2015, 14h25
  2. Réponses: 1
    Dernier message: 13/01/2012, 18h26
  3. Réponses: 7
    Dernier message: 27/04/2011, 12h28
  4. bonne question à propos de l'attribut RENDERED
    Par M.a.n.u. dans le forum JSF
    Réponses: 2
    Dernier message: 26/03/2009, 11h26
  5. attribut "rendered" abcdef
    Par lebesnec dans le forum JSF
    Réponses: 2
    Dernier message: 23/09/2008, 12h15

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo