3

我有一个输入字段,用户可以在其中输入一些产品名称。根据输入的名称,应显示该产品的特定详细信息。在输入更改时,我通过当前字段值从数据源获取产品,并使用AJAX. 到目前为止,用户在输入正确名称之前无法查看产品详细信息。

这是代码示例:

<h:form>
    <h:inputText id="product" value="#{myBean.product}" required="true" converter="productConverter">
        <a4j:ajax event="change" render="product, details"/>
    </h:inputText>

    <rich:message for="product" ajaxRendered="true"/>

    <h:panelGroup id="details">
        <h:outputText rendered="#{not empty myBean.product}" value="#{myBean.product.details}"/>
    </h:panelGroup>

    <a4j:commandButton execute="@form" render="@form" value="Validate" action="validate"/>
</h:form>

转换器

public class ProductConverter implements Converter {

public Object getAsObject(FacesContext context, UIComponent component, String name) {
    return (name != null && ProductDataSource.projectExist(name)) ? new Product(name) : null;
}

public String getAsString(FacesContext context, UIComponent component, Object value) {
    return (value instanceof Product) ? ((Product) value).getName() : "";
}

该产品是必填字段,因此在输入正确名称之前无法提交表单。到目前为止,当用户输入错误的名称时,转换器返回 null 并且验证失败。但我想要的是仅在表单提交时验证此字段,并在重新呈现输入字段时跳过验证。我试图申请immediate="true"两者a4j:ajaxh:inputText但没有任何帮助。有任何想法吗?

提前致谢!

(我正在使用 JSF 2,Richfaces 4)

4

3 回答 3

3

仅当按下提交按钮时才让required属性评估。true您可以通过在请求参数映射中检查其客户端 ID 的存在来做到这一点,如下所示:

<h:inputText ... required="#{not empty param[button.clientId]}" />
...
<a4j:commandButton binding="#{button}" ... />

(不,您不需要将其绑定到 bean 属性,代码按原样完成)

于 2013-02-14T11:56:15.523 回答
0

为了跳过 Jsf 验证,您已添加到表单 write immediate="true" in a4j:commandButton

于 2013-02-14T05:22:10.883 回答
0

尝试使用类似的东西

<a4j:outputPanel ajaxRendered="true">
   <h:inputText id="product" value="#{myBean.product}" required="true" converter="productConverter">
      <a4j:support event="onchange" reRender="details" ajaxSingle="true"/>
   </h:inputText>

   <rich:message id="product" for="details" ajaxRendered="true">
   <h:panelGroup id="details">
      <h:outputText rendered="#{not empty myBean.product}" value="#{myBean.product.details}"/>
   </h:panelGroup>

</a4j:outputPanel>

主要思想是使用ajaxSingle="true"来避免完整的输出面板验证。

于 2014-11-25T06:42:57.073 回答