字段验证适用于ui中的所有组件:repeat

时间:2017-04-28 19:13:33

标签: ajax primefaces jsf-2.2

我正在使用JSF 2.2.8和primefaces 6.0,我正在尝试更新表单中的元素。当我运行我的XHTML时,一切都正确显示但不幸的是,当我开始在输入文件中输入数据时,它不允许我输入数据并且输入掩码应用于每个输入,并且通过显示消息,您必须指示值和字段不是必需的

这是我视图的屏幕 http://imgur.com/a/e5avV

以下是导致问题的代码

    <h:form>
    <ui:repeat  value="#{etpBean.affectations}" var="affectation">
        <ui:repeat var="activite" value="#{etpBean.activites}">
          <p:inputText value="#{etpBean.getValeurActivite(affectation,activite).etp}">
             <p:ajax listener="#{etpBean.onControleChange(affectation)}" process="@this" update=":#{p:component('controle1')}" event="blur" />
               </p:inputText>
         </ui:repeat>
        <ui:repeat var="projet" value="#{etpBean.projet}">
          <p:inputText value="#{etpBean.getValeurActivite(affectation,projet).etp}">
             <p:ajax listener="#{etpBean.onControleChange(affectation)}" process="@this" update=":#{p:component('controle1')}" event="blur" />
               </p:inputText>
         </ui:repeat>
      <h:outputText id="controle1" value="#{affectation.message}"/>                                             
    </ui:repeat
    </h:form>

我尝试添加该过程,但它不起作用。而我还不明白为什么在我尚未提交表单时触发验证。

1 个答案:

答案 0 :(得分:1)

EL范围中有一个隐含的#{component}对象,它计算当前的UI组件。

试试这个

<p:ajax listener="#{etpBean.onControleChange(affectation)}" process="@this" update=":#{p:component('controle')}" event="blur" />