Outils pour utilisateurs

Outils du site


helloworld:design_pattern:bean:java

Ceci est une ancienne révision du document !


Table des matières

Les Beans (Source 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.

<note important>Dans le cas d'une propriété de type boolean, le getter commence par is et non pas get.</note>

Cas général

BeanPersonne.java
package com.llgc;
 
public class BeanPersonne
{
  private int taille = 150;
  private boolean yeuxBleus = false;
  private int[] diplomes = 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;
  }
}

<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>

JSF

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.

  @PostConstruct
  public void init ()
  {
    setTaille (150);
    setYeuxBleus (true);
    setDiplomes (null);
  }

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.

BeanPersonne2.java
package com.llgc;
 
import java.beans.PropertyChangeSupport;
import java.beans.PropertyVetoException;
import java.beans.VetoableChangeSupport;
 
public class BeanPersonne2
{
  private int taille = 150;
  private boolean yeuxBleus = false;
  private int[] diplomes = null;
  private PropertyChangeSupport pcs = new PropertyChangeSupport (this);
  private VetoableChangeSupport vcs = new VetoableChangeSupport (this);
 
  public int getTaille ()
  {
    return taille;
  }
 
  public void setTaille (int taille) throws PropertyVetoException
  {
    int oldTaille = this.taille;
    vcs.fireVetoableChange ("taille", oldTaille, taille);
    this.taille = taille;
    pcs.firePropertyChange ("taille", oldTaille, taille);
  }
 
  public boolean isYeuxBleus ()
  {
    return yeuxBleus;
  }
 
  public void setYeuxBleus (boolean yeuxBleus) throws PropertyVetoException
  {
    boolean oldYeuxBleus = this.yeuxBleus;
    vcs.fireVetoableChange ("yeuxBleus", oldYeuxBleus, yeuxBleus);
    this.yeuxBleus = yeuxBleus;
    pcs.firePropertyChange ("yeuxBleus", oldYeuxBleus, yeuxBleus);
  }
 
  public int[] getDiplomes ()
  {
    return diplomes;
  }
 
  public void setDiplomes (int[] diplomes) throws PropertyVetoException
  {
    int[] oldDiplomes = this.diplomes;
    vcs.fireVetoableChange ("diplomes", oldDiplomes, diplomes);
    this.diplomes = diplomes;
    pcs.firePropertyChange ("diplomes", oldDiplomes, diplomes);
  }
 
  public int getDiplomes (int index)
  {
    return diplomes[index];
  }
 
  public void setDiplomes (int index, int diplome) throws PropertyVetoException
  {
    int oldDiplomes = this.diplomes[index];
    vcs.fireVetoableChange ("diplomes-" + Integer.toString (index), oldDiplomes, diplome);
    this.diplomes[index] = diplome;
    pcs.firePropertyChange ("diplomes-" + Integer.toString (index), oldDiplomes, diplome);
  }
}
helloworld/design_pattern/bean/java.1439112303.txt.gz · Dernière modification : 2015/08/09 11:25 de root