我对在JSF中创建动态组件很感兴趣。我的意思是,根据传递的变量,组件的外观和行为会有所不同。
让我们举一个实际有效的简单示例。一个复合组件(facelet),它根据数据隐藏/显示自身的不同部分。在本例中,它接受一个名为"myBean“的属性,您可以想象它有一个"value”字段和"type“字段。"type“字段确定应该呈现哪个组件。
<?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">
<html xmlns="http://www.w3.org/1999/xhtml"
xmlns:jsp="http://java.sun.com/JSP/Page"
xmlns:h="http://java.sun.com/jsf/html"
xmlns:ui="http://java.sun.com/jsf/facelets"
xmlns:f="http://java.sun.com/jsf/core"
xmlns:c="http://java.sun.com/jsp/jstl/core"
xmlns:cc="http://java.sun.com/jsf/composite">
<cc:interface>
<cc:attribute name="myBean" />
</cc:interface>
<cc:implementation>
<!-- Small input field if type is "shorttext" -->
<h:inputText value="#{myBean.value}" rendered="#{myBean.type == 'shorttext'}" />
<!-- Text area input field if type is "longtext" -->
<h:inputTextArea value="#{myBean.value}" rendered="#{myBean.type == 'longtext'}" />
</cc:implementation>
</html>虽然这是可行的,但它很快就变得笨拙起来。如果我有20个不同的类型,我在同一个文档中指定了所有的类型,这显然违反了好的设计。
相反,我希望能够将实现替换为以下内容:
<ui:include value="#{myBean.type}"/>据我所知,这是不可能的,因为ui:include是在构建组件树时发生的,并且组件是在呈现阶段处理的。
然而,这肯定是一个常见的问题。实现动态组件的最佳方法是什么?我正在使用JSF 2.0,如果这有什么不同的话。
发布于 2010-08-17 19:48:30
我看不到更好的办法。XML不是一种面向对象的语言。这是使用XML所能得到的最好的结果。如果你想用面向对象的方式去做,那么你应该用一个渲染器来创建一个真实的组件。
顺便说一下,复合组件是在JSF2.0中引入的,因此在JSF1.x中不可用。因此,这没有太大的区别;)
https://stackoverflow.com/questions/3500698
复制相似问题