Maison >interface Web >js tutoriel >Comment puis-je déclencher un bean géré JSF à partir d'un événement DOM HTML JavaScript natif ?

Comment puis-je déclencher un bean géré JSF à partir d'un événement DOM HTML JavaScript natif ?

Patricia Arquette
Patricia Arquetteoriginal
2024-12-08 16:00:23495parcourir

How Can I Trigger a JSF Managed Bean from a Native JavaScript HTML DOM Event?

Invocation d'un bean géré par JSF lors d'un événement HTML DOM à l'aide de JavaScript natif

Manipulation de beans gérés par JavaServer Faces lors d'événements HTML DOM à l'aide de natifs JavaScript peut être réalisé par diverses méthodes. Alors que jQuery offre une solution simple avec sa fonction $(document).ready(), JSF propose différentes approches qui s'intègrent parfaitement à son framework.

Utilisation de h:commandScript (JSF 2.3)

Le Le composant permet d'exécuter des actions de bean dans JavaScript sans recourir à une bibliothèque externe comme jQuery. Il crée une fonction JS qui peut être invoquée manuellement ou automatiquement lors de l'événement de chargement DOM en définissant autorun="true". Par exemple :

<h:form>
    <h:commandScript name="commandName" action="#{bean.action}" render=":results" autorun="true" />
</h:form>

Utilisation de p:remoteCommand (PrimeFaces)

PrimeFaces fournit , un composant qui s'intègre de manière transparente à son Moteur Ajax basé sur jQuery. Comparé à , il utilise jQuery pour déclencher la requête Ajax.

<h:form>
    <p:remoteCommand name="commandName" action="#{bean.action}" update=":results" autoRun="true" />
</h:form>

Utilisation de o:commandScript (OmniFaces)

Si votre application utilise OmniFaces, vous pouvez remplacer avec , qui offre des fonctionnalités identiques mais est compatible avec les anciennes versions de JSF 2.x.

<o:form>
    <o:commandScript name="commandName" action="#{bean.action}" render=":results" autorun="true" />
</o:form>

Hidden Form Trick

Un autre L'option implique une astuce de "formulaire caché", où un formulaire contenant un bouton de commande est rendu sur la page mais masqué à l'aide de CSS. Le bouton peut être déclenché à l'aide de la méthode onclick() de JavaScript.

<h:form>
document.getElementById("form:button").onclick();

Custom UIComponent

Pour les scénarios avancés, vous pouvez créer un UIComponent personnalisé extension de UICommand qui génère l'appel natif jsf.ajax.request() de JSF. Cette approche offre une personnalisation et un contrôle complets sur le comportement Ajax.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn