Facelet自定义组件 - 阻止渲染ui:在自定义组件中插入内容

时间:2009-09-30 14:16:59

标签: jsp jsf facelets custom-component

这是我的自定义组件定义:

<ui:composition xmlns="http://www.w3.org/1999/xhtml"
      xmlns:ui="http://java.sun.com/jsf/facelets"
      xmlns:h="http://java.sun.com/jsf/html"
      xmlns:f="http://java.sun.com/jsf/core"
      xmlns:c="http://java.sun.com/jstl/core"
      xmlns:fn="http://java.sun.com/jsp/jstl/functions">
<c:if test="${empty required}">
 <c:set var="required" value="false" />
</c:if>
<c:if test="${empty disabled}">
 <c:set var="disabled" value="false" />
</c:if>
<c:if test="${not disabled}">
<div id="#{id}DIV">
 <label for="#{id}" class="portlet-form-label">${label}</label>
 <ui:insert name="field" />
 <c:if test="${required}">*</c:if>
 <strong class="portlet-msg-error" style="display: none;"><h:message for="#{id}" /></strong>
</div>
</c:if>
</ui:composition>

这就是我使用它的方式:

<my:editLineInsert id="itSIN" label="#{label['label.stocks.income']}" tip="#{label['message.default.tooltip']}" disabled="#{engine.disabled['itSIN']}" required="#{engine.required['itSIN']}" >
 <ui:define name="field">
 <h:inputText id="itSIN"  value="#{order.income}" disabled="#{engine.disabled['itSIN']}" required="#{engine.required['itSIN']}" >
<f:converter converterId="javax.faces.BigDecimal" />
<f:validator validatorId="V12DGS6DECS" />
</h:inputText>
 </ui:define>
</my:editLineInsert>

我遇到<ui:insert name="field" />的问题。它总是呈现。如果disabled = true,我在视图顶部只有<input type="text" disabled="disabled" value="" name="itSIN" id="itSIN"/>元素。注意:我使用ui:insert来传递jsf组件,因为我不知道如何将验证器传递给自定义组件中的h:inputText。

1 个答案:

答案 0 :(得分:1)

我的猜测是你的<c:if>没有按预期工作,因为它们是在组件树构建阶段进行评估然后停止的。看看this page

我个人避免在facelets中使用JSTL标记,因为这些警告会使它们违反直觉。您可以使用“已呈现”属性代替<c:if>代码<ui:fragment><h:panelGroup>