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 :

[JSF2] Charger du code html dynamiquement


Sujet :

JSF Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    802
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 802
    Par défaut [JSF2] Charger du code html dynamiquement
    Bonjour,

    J'ai une application constituée d'un écran principal et de plusieurs boîtes de dialogue pour paramétrer l'appli.

    Je voudrais éviter de charger toutes les boîtes de dialogue dans des div au chargement de l'appli. Je préférerais les charger à la demande.

    Voici ce que j'ai essayé de faire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    <f:view>
    	<h:form>
    		<h:commandButton action="#{lb.display}">
    			<f:ajax render="lightbox"/>
    		</h:commandButton>
    	</h:form>
    	<f:subview id="lightbox" rendered="#{lb.rendered}">
    		<t:lightbox/>
    	</f:subview>
    </f:view>
    La balise <t:lightbox/> correspond à un composant perso. Il ne pose aucun problème et s'affiche correctement.

    Mon ManagedBean :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
     
    @ManagedBean(name="lb")
    public class LightboxBean {
    	private boolean rendered = false;
     
    	public void display() {
    		rendered = true;
    	}
    	public void hide() {
    		rendered = false;
    	}
    	public boolean getRendered() {
    		return rendered;
    	}
    }
    Le problème, vous vous en doutez, c'est que ça ne marche pas. Soit l'attribut rendered est initialisé à true, et le composant s'affiche, soit l'attribut est à false, et le composant ne s'affiche pas, bien que la fonction display() soit bien appellée ainsi que getRendered() lorsque je clique sur le bouton.

    Je pense que je fais fausse route, mais je ne vois pas de solution à mon problème. Avez-vous une idée de la manière dont je pourrais procéder ?

    Merci

  2. #2
    Rédacteur
    Avatar de romaintaz
    Homme Profil pro
    Java craftsman
    Inscrit en
    Juillet 2005
    Messages
    3 790
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Java craftsman
    Secteur : Finance

    Informations forums :
    Inscription : Juillet 2005
    Messages : 3 790
    Par défaut
    Bonsoir,

    Ton souci vient du fait que tu essaies de rafraichir, via Ajax, un composant qui n'existe pas dans la page. En effet, si ton attribut rendered est évalué à false, alors ton composant lightbox ne sera pas présent dans ta page HTML. Lorsque la requête Ajax est retournée, le moteur Ajax qui tourne sur le client va se dire "ok, je dois maintenant rafraichir le composant lightbox. Hé mais une minute, il est où ?" Et là, on ne pourra pas lui dire "DTC" (comprendre Dans Ton Code, bien sûr ), puisque ce composant n'est pas présent dans la page initialement.

    Pour résoudre ce problème, il faut englober ton <f:view> qui contient l'attribut rendered par un autre composant (un div par exemple, généré par un <h:panelGroup layout="block") qui sera toujours présent (mais pourra être vide). Et c'est ce composant que tu vas rafraichir en Ajax.

    Ca donne quelque chose comme ça :

    Code xml : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    <f:view>
    	<h:form>
    		<h:commandButton action="#{lb.display}">
    			<f:ajax render="lightboxWrapper"/>
    		</h:commandButton>
    	</h:form>
    	<h:panelGroup id="lightboxWrapper">
    		<f:subview id="lightbox" rendered="#{lb.rendered}">
    			<t:lightbox/>
    		</f:subview>
    	</h:panelGroup>
    </f:view>
    Nous sommes tous semblables, alors acceptons nos différences !
    --------------------------------------------------------------
    Liens : Blog | Page DVP | Twitter
    Articles : Hudson | Sonar | Outils de builds Java Maven 3 | Play! 1 | TeamCity| CitConf 2009
    Critiques : Apache Maven

  3. #3
    Membre éclairé
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    802
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 802
    Par défaut
    Super, merci Romain, ça marche nickel

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

Discussions similaires

  1. [Windows Phone 7] recuperation de code html dynamique (Scrapping dynamique )
    Par waldpest dans le forum Windows Phone
    Réponses: 0
    Dernier message: 24/03/2014, 08h57
  2. Ajouter du code HTML dynamiquement avec C#
    Par paladice dans le forum ASP.NET
    Réponses: 2
    Dernier message: 17/09/2013, 14h02
  3. Réponses: 1
    Dernier message: 21/11/2007, 09h04
  4. Modification dynamique de code html
    Par xtendance dans le forum Général JavaScript
    Réponses: 3
    Dernier message: 10/10/2006, 11h55
  5. modification dynamique code html
    Par xtendance dans le forum Général JavaScript
    Réponses: 3
    Dernier message: 10/10/2006, 11h09

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