jsf-2 – 在表单提交期间不处理ui:repeat中动态添加的输入字段

前端之家收集整理的这篇文章主要介绍了jsf-2 – 在表单提交期间不处理ui:repeat中动态添加的输入字段前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我试图在我的应用程序中为答案创建一个输入表单,然后从四个“空”答案开始,视图循环并为其创建输入字段.我有一个添加答案按钮,我将一个问题添加到答案数组,然后视图再次呈现答案,但现在有一个额外的输入字段.支持bean是视图编组的.但是,如果我在没有按下添加答案按钮的情况下提交表单,则一切正常.数据保存在数据库中.但是如果我在四个填写完后添加答案,则最后一个不会从输入字段中获取数据(answer.description).如果我先按下添加答案(不填写任何输入字段),则根本不会捕获字段中的数据,所有数据都为空,因此数据库中不会保存任何数据.

我有以下形式:

  1. <ui:repeat var="answer" value="#{bean.answers}">
  2. <div class="field">
  3. <h:outputLabel for="answerAlternative-#{answer.serialNumber}"
  4. value="Svaralternativ #{answer.serialNumber}" />
  5. <h:inputText id="answerAlternative-#{answer.serialNumber}"
  6. value="#{answer.description}" size="40" />
  7. </div>
  8. </ui:repeat>

这是创建新输入字段的方法

  1. public String addAnswer() {
  2. if (answers.size() + 1 < 6) {
  3. Answer answer = new Answer();
  4. answer.setSerialNumber(answerSerialNumber + "");
  5. answerSerialNumber++;
  6. answers.add(answer);
  7. }
  8.  
  9. return null;
  10. }

用于使用四个空输入字段初始化answers数组:

  1. @PostConstruct
  2. public void initBean() {
  3. answers = new ArrayList<Answer>();
  4.  
  5. for (int i = 0; i < 4; i++) {
  6. addAnswer();
  7. }
  8. }

解决方法

这看起来与< ui:repeat>的当前问题相匹配在莫哈拉.在Mojarra是 totally broken.

你基本上有两个选择:

>将Mojarra替换为MyFaces,这样可以更稳定地实施< ui:repeat>.
>使用UIData组件而不是< ui:repeat>,例如<h:dataTable>,Tomahawk的<t:dataList>,PrimeFaces的<p:dataList>

猜你在找的HTML相关文章