我正在我的应用程序中创建自定义标记,但由于某种原因它无法正常工作,我按照this教程(这是我发现最清楚的作为参考),但是,像其他教程一样我做了,我的自定义标签没有被调用。
WEB-INF / example.taglib.xml
<?xml version="1.0" encoding="UTF-8"?>
<facelet-taglib
xmlns="http://java.sun.com/xml/ns/javaee"
version="2.0">
<namespace>http://example.com/facelettags</namespace>
<tag>
<tag-name>hello</tag-name>
<handler-class>example.MenuTagHandler</handler-class>
</tag>
</facelet-taglib>
我的代码处理程序类
package example;
public class MenuTagHandler extends TagHandler {
private String name = "Anonymous";
public MenuTagHandler(TagConfig config) {
//other constructor stuff
Logger.getLogger(MenuTagHandler.class).info("aaaa");
//other constructor stuff
}
@Override
public void apply(FaceletContext context, UIComponent parent) throws IOException {
Logger.getLogger(MenuTagHandler.class).info("aaaa");
UIComponentBase c = new UIComponentBase() {
@Override
public void encodeEnd(FacesContext ctx) throws IOException {
ResponseWriter w = ctx.getResponseWriter();
w.write(String.format(
"<p>Hello %s! I am FaceletTag.</p>",
name));
}
// abstract method in base, must override
@Override
public String getFamily() {
return "com.example.facelettag.test";
}
};
parent.getChildren().add(c);
}
}
我的.xhtml文件
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<ui:composition xmlns="http://www.w3.org/1999/xhtml"
xmlns:ui="http://java.sun.com/jsf/facelets"
xmlns:exampler="http://example.com/facelettags" >
<example:hello />
</ui:composition>
渲染结果为
<example:hello></example:hello>
遗憾的是,日志中没有打印任何内容,是否有人知道为什么它没有调用标记处理程序?
答案 0 :(得分:0)
如果*.taglib.xml
文件不在放置在/META-INF
中的JAR文件的/WEB-INF/lib
内,则不会自动检测和注册(如同所有情况一样)那些第三方JSF组件库,如PrimeFaces,RichFaces等),那么你需要在webapp的web.xml
中手动注册它,如下所示:
<context-param>
<param-name>javax.faces.FACELETS_LIBRARIES</param-name>
<param-value>/WEB-INF/example.taglib.xml</param-value>
</context-param>
无关,请注意您目前所处的不是自定义组件。这是一个自定义标记处理程序,它反过来创建一个UIComponentBase
的匿名实例。这不一定是“最好”的做法。如果在视图构建期间不需要执行与组件树相关的任何操作,则根本不需要taghandler部分。只需创建一个值得信赖的@FacesComponent
课程。