Outils pour utilisateurs

Outils du site


helloworld:design_pattern:bean:java

Différences

Ci-dessous, les différences entre deux révisions de la page.

Lien vers cette vue comparative

Les deux révisions précédentesRévision précédente
Prochaine révision
Révision précédente
helloworld:design_pattern:bean:java [2015/08/08 21:09] – ↷ Liens modifiés en raison d'un déplacement. roothelloworld:design_pattern:bean:java [2020/04/26 23:00] (Version actuelle) – Conversion de <note> vers <WRAP> root
Ligne 1: Ligne 1:
-Les Beans ([[https://docs.oracle.com/javase/tutorial/javabeans/index.html|Source]] {{:helloworld:design_pattern:beans.tar.xz|Archive}}) sont des classes permettant le stockage de données. Les données sont stockées sous forme de propriétés privées et sont modifiées par des ''getters'' et ''setters'' publics.+Les Beans ([[https://docs.oracle.com/javase/tutorial/javabeans/index.html|Trail: JavaBeans]] {{:helloworld:design_pattern:bean:java:beans.tar.xz|Archive tar.xz}}) sont des classes permettant le stockage de données. Les données sont stockées sous forme de propriétés privées et sont modifiées par des ''getters'' et ''setters'' publics.
  
-<note important>Dans le cas d'une propriété de type ''boolean'', le ''getter'' commence par ''is'' et non pas ''get''.</note>+<WRAP center round important 60%> 
 +Dans le cas d'une propriété de type ''boolean'', le ''getter'' commence par ''is'' et non pas ''get''. 
 +</WRAP>
  
-=====Java=====+=====Cas général=====
 <file java BeanPersonne.java> <file java BeanPersonne.java>
 package com.llgc; package com.llgc;
Ligne 55: Ligne 57:
 </file> </file>
  
-<note>Tous les Bean doivent contenir un constructeur sans argument. Lorsque aucun constructeur n'est défini, un constructeur sans argument est implicitement créé par Java. Cependant, si un constructeur avec argument est déclaré, il conviendra de déclarer explicitement le constructeur sans argument.</note>+<WRAP center round info 60%> 
 +Tous les Bean doivent contenir un constructeur sans argument. Lorsque aucun constructeur n'est défini, un constructeur sans argument est implicitement créé par Java. Cependant, si un constructeur avec argument est déclaré, il conviendra de déclarer explicitement le constructeur sans argument. 
 +</WRAP>
  
 +=====JSP et JSF=====
 +Dans le cas d'une utilisation du Bean via JSP et JSF, il est nécessaire de passer la classe en bean managé (''@ManagedBean'') et les attributs modifiables par une page ''JSP''/''JSP'' en attributs managés (''@ManagedProperty'').
 +
 +<WRAP center round important 60%>
 +Si un attribut est managé (avec ''@ManagedProperty''), il n'est pas possible de définir une valeur par défaut avec le constructeur ou en définissant une valeur par défaut à l'attribut. Il faut définit une fonction d'initialisation avec l'annotation ''@PostConstruct''.
 +
 +Le cycle de vie d'un Bean passe par le constructeur, puis la page JSP/JSF effectue un ''set* (0 ou null)'' sur l'ensemble des attributs managés et enfin exécute la méthode désignée par l'annotation ''@PostConstruct''.
 +</WRAP>
 +
 +<code java>
 +package com.llgc;
 + 
 +import java.util.Arrays;
 +
 +import javax.annotation.PostConstruct;
 +import javax.faces.bean.ManagedBean;
 +import javax.faces.bean.ManagedProperty;
 + 
 +@ManagedBean
 +public class BeanPersonne
 +{
 +  @ManagedProperty(value="#{taille}")
 +  private int taille;
 +  @ManagedProperty(value="#{yeuxBleus}")
 +  private boolean yeuxBleus;
 +  @ManagedProperty(value="#{diplomes}")
 +  private int[] diplomes;
 +  
 +  @PostConstruct
 +  private void init ()
 +  {
 +    setTaille (150);
 +    setYeuxBleus (true);
 +    setDiplomes (null);
 +  }
 + 
 +  public int getTaille ()
 +  {
 +    return taille;
 +  }
 + 
 +  public void setTaille (int taille)
 +  {
 +    this.taille = taille;
 +  }
 + 
 +  public boolean isYeuxBleus ()
 +  {
 +    return yeuxBleus;
 +  }
 + 
 +  public void setYeuxBleus (boolean yeuxBleus)
 +  {
 +    this.yeuxBleus = yeuxBleus;
 +  }
 + 
 +  public int[] getDiplomes ()
 +  {
 +    return diplomes;
 +  }
 + 
 +  public void setDiplomes (int[] diplomes)
 +  {
 +    this.diplomes = diplomes;
 +  }
 + 
 +  public int getDiplomes (int index)
 +  {
 +    return diplomes[index];
 +  }
 + 
 +  public void setDiplomes (int index, int diplome)
 +  {
 +    this.diplomes[index] = diplome;
 +  }
 + 
 +  @Override
 +  public String toString ()
 +  {
 +    return "BeanPersonne [taille=" + taille + ", yeuxBleus=" + yeuxBleus + ", diplomes=" + Arrays.toString (diplomes)
 +        + "]";
 +  }
 +}
 +</code>
 +=====Support des Listener=====
 Il est également possible de configurer un Bean pour être surveillé dans ces modifications voir même empêché par un autre composant. Il est également possible de configurer un Bean pour être surveillé dans ces modifications voir même empêché par un autre composant.
  
Ligne 127: Ligne 216:
 } }
 </file> </file>
- 
-Dans le cas d'une utilisation du Bean depuis l'implémentation de JSF, il est nécessaire d'utiliser l'annotation ''@PostConstruct'' sur une méthode d'initialisation car les attributs définis lors de leur déclaration ou dans le constructeur sont remplacés par une valeur nulle. 
-<code java> 
-  @PostConstruct 
-  public void init () 
-  { 
-    setTaille (150); 
-    setYeuxBleus (true); 
-    setDiplomes (null); 
-  } 
-</code> 
helloworld/design_pattern/bean/java.1439060959.txt.gz · Dernière modification : 2015/08/08 21:09 de root