Je suis nouveau sur JSF 2. Ma question est liée à la réponse de BalusC à cette question jsf2 ajax update parts based on request parameters J'ai essayé le code kickstart BalusC publié et j'ai rencontré une erreur d'analyse EL:
/nameofpage.xhtml @12,64 rendered="#{bean.panels.contains('u1')}"
Error Parsing: #{bean.panels.contains('u1')}
Je suppose que cela est dû au fait que je n'exécute pas un conteneur compatible Servlet 3.0/EL 2.2 avec un /WEB-INF/web.xml déclaré conformément à la spécification Servlet 3.0. J'utilise Tomcat 6.
BalusC a suggéré dans sa réponse de créer une fonction EL personnalisée. Mais comment puis-je accomplir cela en utilisant une fonction EL personnalisée? Ou cela peut-il être résolu en configurant simplement certaines parties de mon projet?
Ci-dessous est mon web.xml
:
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://Java.Sun.com/xml/ns/javaee" xmlns:web="http://Java.Sun.com/xml/ns/javaee/web-app_2_5.xsd" xsi:schemaLocation="http://Java.Sun.com/xml/ns/javaee http://Java.Sun.com/xml/ns/javaee/web-app_2_5.xsd" version="2.5">
<servlet>
<servlet-name>Faces Servlet</servlet-name>
<servlet-class>javax.faces.webapp.FacesServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>Faces Servlet</servlet-name>
<url-pattern>*.jsf</url-pattern>
</servlet-mapping>
<context-param>
<param-name>javax.faces.PROJECT_STAGE</param-name>
<param-value>Development</param-value>
</context-param>
<welcome-file-list>
<welcome-file>index.jsp</welcome-file>
<welcome-file>index.html</welcome-file>
</welcome-file-list>
</web-app>
Créez d'abord une classe final
avec un public static
méthode qui fait exactement le travail que vous voulez:
package com.example;
import Java.util.Collection;
public final class Functions {
private Functions() {
// Hide constructor.
}
public static boolean contains(Collection<Object> collection, Object item) {
return collection.contains(item);
}
}
Définissez-le ensuite comme facelet-taglib
dans /WEB-INF/functions.taglib.xml
:
<?xml version="1.0" encoding="UTF-8"?>
<facelet-taglib
xmlns="http://Java.Sun.com/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://Java.Sun.com/xml/ns/javaee http://Java.Sun.com/xml/ns/javaee/web-facelettaglibrary_2_0.xsd"
version="2.0">
<namespace>http://example.com/functions</namespace>
<function>
<function-name>contains</function-name>
<function-class>com.example.Functions</function-class>
<function-signature>boolean contains(Java.util.Collection, Java.lang.Object)</function-signature>
</function>
</facelet-taglib>
Familiarisez ensuite Facelets avec le nouveau taglib dans le /WEB-INF/web.xml
:
<context-param>
<param-name>javax.faces.FACELETS_LIBRARIES</param-name>
<param-value>/WEB-INF/functions.taglib.xml</param-value>
</context-param>
(remarque: si vous avez déjà le javax.faces.FACELETS_LIBRARIES
défini, alors vous pouvez simplement ajouter le nouveau chemin séparé par un point-virgule)
Définissez-le ensuite dans le fichier Facelets XHTML comme nouvel espace de noms XML:
<html
xmlns="http://www.w3.org/1999/xhtml"
xmlns:f="http://Java.Sun.com/jsf/core"
xmlns:h="http://Java.Sun.com/jsf/html"
xmlns:func="http://example.com/functions"
...
>
Enfin, vous pouvez l'utiliser comme prévu:
rendered="#{func:contains(bean.panels, 'u1')}"
Comme alternative complètement différente, vous pouvez également inclure JBoss EL dans votre projet. Il fonctionne sur Tomcat 6.0 et vous pourrez invoquer des méthodes non getter dans EL. Drop jboss-el.jar fichier dans /WEB-INF/lib
et ajoutez ce qui suit à votre web.xml
:
<context-param>
<param-name>com.Sun.faces.expressionFactory</param-name>
<param-value>org.jboss.el.ExpressionFactoryImpl</param-value>
</context-param>
Depuis EL 2.2, il existe une autre approche: créer un @ApplicationScoped
bean avec des méthodes faisant à leur tour référence à ces fonctions statiques. Voir aussi a.o. Méthodes utilitaires dans le bean à portée d'application .