RichFaces - Concepts de base

Dans ce chapitre, nous verrons quelques concepts de base de RichFaces et nous apprendrons comment RichFaces gère le traitement des requêtes AJAX et de nombreuses autres fonctionnalités.

Traitement de la demande AJAX

Comme mentionné précédemment, RichFaces fournit des composants d'interface utilisateur riches qui activent les fonctionnalités AJAX dans l'application Web, même sans implémenter de codes AJAX. Toutes ces fonctionnalités AJAX sont introduites viaa4:j bibliothèque de balises. <a4j:commandLink> , <a4j:commandButton>, <a4j:support>, et <a4j:poll>sont les quatre balises qui aident le développeur à intégrer les fonctionnalités AJAX dans l'application Web. Nous en apprendrons plus sur les bibliothèques de balises dans un chapitre suivant.

Traitement d'arbre partiel

Dans une application AJAX conventionnelle, tous les champs d'entrée seront traités comme différents nœuds d'un arbre, cependant, dans RichFaces, nous avons la possibilité de soumettre partiellement les nœuds de l'arbre et de valider les champs requis.

Prenons un exemple pour en comprendre davantage. Supposons qu'il y ait un total de cinq éléments en HTML - «Nom», «ID de l'employé», «Salaire de l'employé», «Adresse de l'employé» et «Service de l'employé». Vous souhaitez maintenant valider ou traiter uniquement l'identifiant d'employé, ce qui peut être possible avec RichFaces mais pas possible avec AJAX. Vous devez soumettre le formulaire complet au serveur. RichFaces fournit un attribut d'exécution qui peut identifier un composant spécifique et le traiter. Voici les différents niveaux d'attributs d'exécution disponibles.

  • @all - Cet attribut traitera toutes vos données.

  • @none - Cela peut être utilisé lorsque vous ne souhaitez traiter aucune des données.

  • @this - Cela traitera uniquement le composant demandeur.

  • @form - Cela traitera le formulaire entier qui contient le composant demandeur.

  • @region - Cela traitera une région spécifique d'une page Web.

Mises à jour de vue partielle

Tout comme les champs de saisie, RichFaces propose des options similaires pour mettre à jour différentes vues. Les développeurs peuvent personnaliser la vue selon leur choix. Comme l'attribut d'exécution, il existe un attribut de rendu qui fonctionne de la même manière que l'attribut d'exécution. Tous ces attributs fonctionnent sur la base de l'identifiant d'identification d'une page Web.

Voici les différents niveaux d'attributs de rendu disponibles.

  • @all - Cela mettra à jour l'ensemble du composant.

  • @none - Cela ne mettra à jour aucun de vos composants.

  • @this - Cela mettra à jour uniquement le composant demandeur.

  • @from - Cela mettra à jour le formulaire qui contient les données demandées.

  • @region - Cela mettra à jour une région spécifique de la page Web.

Autres balises a4j

Jusqu'à présent, nous avons discuté des propriétés conceptuelles de l'application RichFaces. Dans cette section, nous en apprendrons plus sur eux avec des exemples pratiques.

<a4j: AJAX>

C'est l'un des principaux composants proposés par RichFaces. Ce n'est rien d'autre qu'une partie étendue de la balise JSF2.0 f: AJAX. Cette balise déclenche une requête AJAX chaque fois qu'un événement JS se produit dans les pages Web. L'exemple suivant décrit plus en détail cette balise. Créez une page «xhtml» sous le dossier de la page Web et nommez-la «a4jAJAXExample.xhtml». Ensuite, collez le morceau de code suivant.

<!DOCTYPE html> 
<html xmlns = "http://www.w3.org/1999/xhtml"   
   xmlns:h = "http://xmlns.jcp.org/jsf/html"   
   xmlns:a4j = "http://richfaces.org/a4j">   
   
   <h:head>   
      <title>a4j:AJAX Tag Example</title>   
   </h:head>   

   <h:body>  
      <h:form id = "form"> 
         <h:inputText value = "#{managedBean.message}"> 
            <a4j:AJAX render = "ShowMessage" /> 
         </h:inputText> 
         
         <h:outputText value = "#{managedBean.message}" id = "ShowMessage" 
            style = "animation-duration"/> 
      </h:form> 
   </h:body> 
   
</html>

Nous devons également créer un bean géré afin de conserver les entrées de la page Web. Allez-y et créez une classe java sous le répertoire du package source. Voici lemanagedbean.java code de la classe.

import javax.faces.bean.ManagedBean;   
import javax.faces.bean.RequestScoped;   

@ManagedBean   
@RequestScoped   

public class managedBean {   
   String message;   
   public String getMessage() {   
      return message;   
   }   
   public void setMessage(String message) {   
      this.message = message;   
   }   
}

Enregistrez les deux fichiers et exécutez, ce qui donnera la sortie suivante dans le navigateur.

<a4j: param>

a4j: param est une extension de la balise f: param. Il est utilisé pour affecter une valeur à une propriété ou à une variable d'instance. Cette balise est capable d'attribuer la valeur à la variable d'instance de manière permanente. Voici le code «a4jparamExample.html».

<?xml version = "1.0" encoding = "UTF-8"?>  
<!DOCTYPE html> 
<html xmlns = "http://www.w3.org/1999/xhtml"   
   xmlns:h = "http://xmlns.jcp.org/jsf/html"   
   xmlns:a4j = "http://richfaces.org/a4j">  
   
   <h:head> 
      <title>Param tag example</title> 
      <meta name = "viewport" content = "width = device-width, initial-scale = 1.0"/> 
   </h:head> 
   
   <h:body> 
      <h:form id = "form"> 
         <h:panelGrid columns = "2"> 
            <a4j:commandButton value = "TutorialsPoint" render = "rep"> 
               <a4j:param value = "Tutorials point" assignTo = "#{managedBean.message}" /> 
            </a4j:commandButton> 
  
            <a4j:commandButton value = "RichFace Tutorials" render = "rep"> 
               <a4j:param value = "RichFace Tutorials" assignTo = "#{managedBean.message}" /> 
            </a4j:commandButton> 
         </h:panelGrid> 
         <br /> 
         
         <h:outputText id = "rep" value = "Selected Name:#{managedBean.message}" /> 
      </h:form> 
   </h:body> 
   
</html>

Voici le code de classe de bean géré correspondant.

import javax.faces.bean.ManagedBean;   
import javax.faces.bean.RequestScoped;   

@ManagedBean   
@RequestScoped   

public class managedBean {   
   String message;   
   public String getMessage() {   
      return message;   
   }   
   public void setMessage(String message) {   
      System.out.println("This method is getting called with"+message); 
      
      // we have added this line in order to check how the AJAX call 
      // happens to the class methods without any direct communication  
      this.message = message;   
   }   
}

Allez-y et exécutez le fichier. Voici la sortie dans le navigateur.

Maintenant, dans la console du serveur, vous verrez la sortie suivante, qui prouve que le fichier xhtml communique avec le bean géré afin de définir la variable d'instance au moment de l'exécution.

<a4j: commandButton>

Nous avons déjà utilisé la balise du bouton de commande dans notre exemple précédent. Il est utilisé pour créer un bouton à l'intérieur d'une page xhtml, qui générera et communiquera avec le moteur AJAX pour traiter la demande spécifique. Il prend une entrée et traite la même chose et restitue une sortie dans le navigateur Web.

Dans l'exemple précédent, nous avons créé deux boutons - «TutorialsPoint» et «RichFace Tutorials». Notre balise de bouton de commande communique en interne avec le bean géré et définit les variables d'instance requises. Il est également responsable du rendu de la valeur.

<a4j: commandLink>

Le lien de commande fonctionne comme le composant <h: commandlink> de JSF 2.0. Le bouton de commande génère une requête AJAX basée sur l'envoi, chaque fois que le lien de commande fonctionne sur l'événement de clic JS. C'est la seule différence que nous avons dans le bouton de commande et le lien de commande. L'exemple suivant vous aidera à mieux comprendre la balise lib. Créez le fichier «a4jCommandLink.xhtml» et collez-y le code suivant.

<?xml version = "1.0" encoding = "UTF-8"?>  
<!DOCTYPE html> 
<html xmlns = "http://www.w3.org/1999/xhtml"   
   xmlns:h = "http://xmlns.jcp.org/jsf/html"   
   xmlns:a4j = "http://richfaces.org/a4j">  
   
   <h:head> 
      <title>Example of command Link</title> 
   </h:head> 
    
   <h:body> 
      <h:form id = "form">
         <h:panelGrid columns = "3"> 
            <h:outputText value = "Name:" /> 
            <h:inputText value = "#{managedBean.message}" /> 
             <a4j:commandLink value = "Click Me" render = "out" execute = "@form" /> 
         </h:panelGrid> 
      </h:form> 
      <br /> 
      
      <a4j:outputPanel id = "out"> 
         <h:outputText value = "Welcome to #{managedBean.message} !" /> 
      </a4j:outputPanel> 
   </h:body> 
   
</html>

Pas besoin de changer quoi que ce soit dans la classe de bean géré. Exécutez ce fichier et ce qui suit sera la sortie dans le navigateur.

<a4j: outputPanel>

Le panneau de sortie fonctionne comme une étendue de la page HTML. Il est utilisé pour regrouper différents composants d'une page Web plutôt que de les spécifier individuellement. Dans l'exemple précédent, nous avons utilisé le panneau de sortie pour afficher le message fourni dans la zone de texte d'entrée. Voici la syntaxe du panneau de sortie.

<a4j:outputPanel id = "out"> 
   <h:outputText value = "Welcome to #{managedBean.message} !" /> 
</a4j:outputPanel>

<a4j: region>

C'est la caractéristique clé de RichFaces, qui permet de traiter certaines parties de la page Web à partir de. En utilisant cette balise, le traitement partiel de l'arborescence se produit dans RichFaces. Il est principalement utilisé pour augmenter le processus de rendu. L'exemple suivant vous aidera à comprendre cela en détail. Veuillez créer un fichier «a4jregionExample.xhtml» en utilisant le code suivant.

<?xml version = "1.0" encoding = "UTF-8"?> 
<!DOCTYPE html> 
<html xmlns = "http://www.w3.org/1999/xhtml"   
   xmlns:h = "http://java.sun.com/jsf/html" 
   xmlns:a4j = "http://richfaces.org/a4j" >  
   
   <h:head> 
      <title>Region Example</title>       
   </h:head> 
    
   <h:body> 
      <h:form> 
         <h:inputText value = "#{managedBean.message}"/> 
         <h:inputText value = "#{managedBean.job}"/> 
         <a4j:commandLink id = "one" value = "one"/> 
         
         <a4j:region> 
            <h:inputText value = "#{managedBean.message}"/> 
            <a4j:commandLink id = "two" value = "two"/> 
         </a4j:region>
      </h:form>  
   </h:body> 
   
</html>

Avec cette page xhtml, veuillez mettre à jour notre managedBean en conséquence.

import javax.faces.bean.ManagedBean;   
import javax.faces.bean.RequestScoped;   

@ManagedBean   
@RequestScoped   

public class managedBean {   
   String message;  
   String job; 
      public String getMessage() {   
      return message;   
   }   
   public void setMessage(String message) {   
      System.out.println("setMessage method is getting called with--"+message); 
      this.message = message;   
   } 
   public String getJob() { 
      return job; 
   } 
   public void setJob(String job) { 
      System.out.println("setJob method is getting called with--"+job); 
      this.job = job; 
   } 
}

Le morceau de code ci-dessus donnera la sortie suivante dans le navigateur.

Chaque fois que le lien de commande «un» est cliqué, il traitera le formulaire entier, cependant, lorsque nous cliquons sur le lien de commande «deux», seule l'instance de message sera traitée car elle est incluse dans une balise de région. De même, si nous enfermons le lien de commande «un» dans une autre balise de région, alors il ne traitera que les deux premiers paramètres d'entrée. Voici la capture d'écran de la console du serveur, chaque fois que le lien de commande «deux» est cliqué.

Chaque fois que le lien de commande «un» est cliqué, ce qui suit sera la sortie.

<a4j: répéter>

La balise de répétition fonctionne exactement de la même manière que la balise <ui: repeat> de JSF. Cela aide à parcourir une liste dans la page Web. Dans l'exemple suivant de fichier «a4jRepeat.xhtml», nous parcourons une liste de notre classe de bean géré.

<?xml version = "1.0" encoding = "UTF-8"?> 
<!DOCTYPE html> 
<html xmlns = "http://www.w3.org/1999/xhtml"   
   xmlns:h = "http://java.sun.com/jsf/html" 
   xmlns:a4j = "http://richfaces.org/a4j"> 
   
   <h:head></h:head> 
   
   <h:body> 
      <h:form id = "form"> 
         <h:panelGrid columns = "1" style = "width: 640px"> 
            <a4j:outputPanel id = "panel" layout = "block"> 
               <a4j:repeat       value = "#{managedBean.subjectList}" var = "sub"> 
                  <li> 
                     <h:outputText value = "#{sub}"/> 
                  </li> 
               </a4j:repeat> 
            </a4j:outputPanel> 
         </h:panelGrid> 
      </h:form> 
   </h:body> 
   
</html>

Une fois que vous exécutez ce fichier spécifique dans le navigateur, vous obtiendrez la sortie suivante.

<a4j: status>

Comme son nom l'indique, cette balise est utile chaque fois que vous souhaitez afficher l'état de votre requête AJAX dans le front-end. Vous pouvez inclure un message texte normal ou un gif ou un statut basé sur une image selon votre choix. Pour une petite application telle que la suivante, vous aurez un aperçu de l'état dans le front-end, cependant, chaque fois que vous exécutez une requête AJAX complexe, cet état est très visible. Veuillez modifier le "a4jregionExample.xhtml" comme indiqué ci-dessous.

<?xml version = "1.0" encoding = "UTF-8"?> 
<!DOCTYPE html> 
<html xmlns = "http://www.w3.org/1999/xhtml"   
   xmlns:h = "http://java.sun.com/jsf/html" 
   xmlns:a4j = "http://richfaces.org/a4j">  
   
   <h:head> 
      <title>Region Example</title> 
   </h:head> 
    
   <h:body> 
      <h:form> 
         <a4j:status startText = "Working..." /> 
            <h:inputText value = "#{managedBean.message}"/> 
            <h:inputText value = "#{managedBean.job}"/> 
            <a4j:commandLink id = "one" value = "one"/>
            
            <a4j:region> 
               <h:inputText value = "#{managedBean.message}"/> 
               <a4j:commandLink id = "two" value = "two"/> 
            </a4j:region> 
            
         <a4j:status startText = "Done" /> 
      </h:form>  
   </h:body> 
   
</html>

Chaque fois que vous exécutez cette application, vous pouvez voir un aperçu de deux états «fonctionnement ...» et «Terminé». Ces statuts disparaîtront automatiquement à chaque fois que la demande sera complétée.

<a4j: include> / <a4j: keepAlive>

Inclure et keepAlive, les deux balises ont été introduites dans RichFaces 3.0, mais dans RichFaces 4, ces balises ont été dépréciées car ces fonctionnalités peuvent être facilement réalisables en utilisant différentes autres balises utilisées dans Facelets telles que <ui: include> et <ui: insert>. Comme son nom l'indique, include a été introduit pour inclure une page dans une autre et keepAlive a été introduit pour contrôler la portée du bean géré associé à une page JSF. Il est recommandé d'utiliser la version mise à jour de toutes les API logicielles et d'utiliser le composant <UI> et l'implémentation «d'annotation» pour atteindre les objectifs commerciaux.

<a4j: log>

Comme son nom l'indique, ce composant a4j aide à générer les informations de journalisation dans le navigateur Web. L'exemple suivant explique plus en détail cette balise. Modifiez le fichier «a4jregionExample.xhtml» de la manière suivante.

<?xml version = "1.0" encoding = "UTF-8"?> 
<!DOCTYPE html> 
<html xmlns = "http://www.w3.org/1999/xhtml" 
   xmlns:ui = "http://java.sun.com/jsf/facelets" 
   xmlns:h = "http://java.sun.com/jsf/html" 
   xmlns:a4j = "http://richfaces.org/a4j">  
   
   <h:head> 
      <title>Region Example</title> 
   </h:head> 
    
   <h:body>
      <h:form> 
         <a4j:status startText = "Working..." /> 
            <h:inputText value = "#{managedBean.message}"/> 
            <h:inputText value = "#{managedBean.job}"/> 
            <a4j:commandLink id = "one" value = "one"/> 
            
            <a4j:region> 
               <h:inputText value = "#{managedBean.message}"/> 
               <a4j:commandLink id = "two" value = "two"/> 
            </a4j:region> 
            
            <a4j:log></a4j:log> 
         <a4j:status startText = "Done" /> 
      </h:form>  
   </h:body>
   
</html>

Maintenant, exécutez le code ci-dessus dans le navigateur et ce qui suit sera la sortie. a4j: log générera les journaux requis de tous les niveaux chaque fois que nécessaire.

<a4j: jsFunction>

Il s'agit de la fonctionnalité la plus avancée de RichFaces, où une fonction JS automatique peut être créée sans aucun code JavaScript. Le CDK générera un code JavaScript automatique basé sur n'importe quel événement JS.

Dans l'exemple suivant, nous créons une fonction JavaScript qui sera appelée chaque fois que nous survolons une valeur spécifiée.

<?xml version = "1.0" encoding = "UTF-8"?> 
<!DOCTYPE html> 
<html xmlns = "http://www.w3.org/1999/xhtml" 
   xmlns:ui = "http://java.sun.com/jsf/facelets" 
   xmlns:h = "http://java.sun.com/jsf/html" 
   xmlns:a4j = "http://richfaces.org/a4j">  
   
   <h:head> 
      <title>Example of JS Function</title> 
   </h:head> 
    
   <h:body> 
      <table width = "500" border = "1"> 
         <tbody> 
            <tr> 
               <td>
                  <span onmouseover = "showMySkill('core java,J2EE')" 
                     onmouseout = "showMySkill('')">BackEnd developer</span>
               </td> 
               <td>
                  <span onmouseover = "showMySkill('DB,RDBMS,unix')" 
                     onmouseout = "showMySkill('')">Database Admin</span>
               </td> 
               <td>
                  <span onmouseover = "showMySkill(
                     'JS frameworks,html,java scripts')" 
                     onmouseout = "showMySkill('')">Front End Developer</span>
               </td> 
            </tr> 
            <tr> 
               <td colspan = "3">You need to know: 
                  <b><h:outputText id = "showSkillset" value = "#{managedBean.message}"/></b>
               </td> 
            </tr> 
         </tbody> 
      </table> 
      
      <h:form id = "form"> 
         <a4j:jsFunction name = "showMySkill" render = "showSkillset"> 
            <a4j:param name = "name" assignTo = "#{managedBean.message}" /> 
         </a4j:jsFunction> 
      </h:form> 
   </h:body> 
</html>

Le code ci-dessus générera la sortie suivante dans le navigateur. En fonction de l'événement JS, CDK remplacera la méthode nommée «showMySkill ()» et les valeurs requises seront imprimées dans le navigateur.

<a4j: AJAXListener>

Cette balise est utilisée lorsque vous souhaitez exécuter un écouteur particulier juste avant de rendre le résultat au navigateur. Cette balise n'est pas disponible dans RichFaces 4 car la même fonctionnalité est disponible dans , où vous pouvez créer une requête AJAX sur n'importe quelle occurrence d'événement JS. Bien qu'il soit conseillé d'utiliser la version mise à jour du logiciel, si vous utilisez toujours RichFaces 3, vous pouvez utiliser cette balise de la manière suivante.

<rich:panel> 
   <f:facet name = "header">Using a4j:actionListener</f:facet> 
   <a4j:commandButton value="Submit" reRender = "#{AJAXBean.areas}"> 
      <a4j:AJAXListener binding = "#{AJAXBean.renderAreasListener}"/> 
   </a4j:commandButton> 
</rich:panel>

Dans l'exemple ci-dessus, en cliquant sur le bouton «Soumettre», un événement JS sera créé, qui appellera la méthode «aires» implémentée à l'intérieur de la classe de bean et le résultat correspondant sera rendu en conséquence.