1

追加ページに移動するリスティング ページがあります。追加ページには名前のテキストボックスがあり、その値はセッションスコープの Beanにバインドされています。

一覧ページには、アクション メソッドを介して追加ページに移動する追加ボタンがあります。このアクション メソッドは、名前のテキスト ボックスがバインドされているオブジェクトをクリアします。

また、追加ページにキャンセル ボタンがあります。これは、名前のテキスト ボックスがバインドされている値を再度クリアするアクション メソッドにバインドされています。

何も即時に設定されていない場合、これはすべて正常に機能します。

ただし、キャンセル ボタンを即時に設定し、名前フィールドに値を入力してからキャンセルをクリックすると、アクション メソッドが起動され、バッキング Bean のオブジェクトがクリアされ、リスト ページに移動します。次に追加をクリックすると、アクション メソッドはオブジェクトを再度クリアし (最適な方法であるかどうかは無視してください)、追加ページに移動します。追加ページの名前のテキスト ボックスが空であることが期待されますが、そうではありませんか?! 確かに、追加ボタンはすぐに表示されないため、値は再バインドされて空になるはずですか?

以下は、リスト ページの追加ボタンに関連する XHTML です。

<h:commandButton id="addButton"
                 value="Add"
                 action="#{myBean.gotoAdd}"/>

以下は、追加ページ (myBean はセッション スコープ) の入力ボックスに関連する XHTML であり、その後に追加ページのキャンセル ボタンの XHTML が続きます。

<h:inputText id="newName"
             value="#{myBean.newObject.name}"
             binding="#{myBean.newNameInput}"
             styleClass="name" />

<h:commandButton id="cancelButton"
                 value="Cancel" immediate="true"
                 action="#{myBean.cancelAdd}"
                 onclick="return confirm('You sure?');"/>
4

4 に答える 4

2

bindingリストのどのアイテムにアクションが発生したかを特定する必要がある場合を除いて、タグのプロパティを使用することはほとんどありません。そのため、タグの使用については特によく知らされていません。ただしbinding、コードを使用しなくても期待どおりに機能する可能性が高いことはわかっているので、javax.faces.component.UIxxxバインドしているオブジェクトが正しくリセットされないことが予想されます。

于 2010-03-31T19:00:20.147 に答える
1

私は今、非常によく似た問題を抱えています。

バインディングおよび/またはイミディエート属性を削除することに加えて、「追加」ボタンをクリックしたときに呼び出されるアクションからバインディングを使用して、コンポーネントでsetSubmittedValue()を呼び出してみてください。

残念ながら、それがあなたを助けたとしても、キャンセル後に同じコンポーネントを表示することにつながる可能性のあるアクションでそれを行う必要があります。

だから私はまだいくつかのより良い解決策を見つけようとしています...

于 2010-06-08T15:28:05.203 に答える
0

即時="true"を使用すると、値が保持されます。これがパラメーターの動作方法です。次のリンクを確認する必要があります。

http://wiki.apache.org/myfaces/How_The_Immediate_Attribute_Works

http://wiki.apache.org/myfaces/ClearInputComponents

于 2010-04-01T05:14:05.560 に答える
0

わかりました、これは私がゼロから行った例です。2 つのキャンセル ボタンがあります。再現手順の例:

  • james-list ページに移動し、[追加] をクリックします。
  • 空のフィールドを含む追加ページが表示されます。すべてのフィールドに値を入力し、[追加] をクリックします。
  • リスト ページが表示され、更新されて新しい人物が含まれます。[追加] をクリックします。
  • 空のフィールドを含む追加ページが表示されます。すべてのフィールドに値を入力し、[キャンセル (即時)] をクリックします。
  • リスト ページが表示され、変更されません。[追加] をクリックします。
  • 追加ページが表示されますが、期待どおりにフィールドが空ではありません。[キャンセル] をクリックします。
  • リスト ページが表示され、変更されません。[追加] をクリックします。
  • 追加ページが表示され、フィールドが空ではなくなりました。

James.java:

package com.jamiebarrow;

import java.util.ArrayList;
import java.util.List;
import javax.faces.bean.ManagedBean;
import javax.faces.bean.SessionScoped;
import javax.faces.component.UIComponent;

@ManagedBean
@SessionScoped
public class James {

  private UIComponent idComponent;
  private UIComponent firstNameComponent;
  private UIComponent lastNameComponent;

  public UIComponent getIdComponent() {
    return idComponent;
  }

  public void setIdComponent(UIComponent idComponent) {
    this.idComponent = idComponent;
  }

  public UIComponent getFirstNameComponent() {
    return firstNameComponent;
  }

  public void setFirstNameComponent(UIComponent firstNameComponent) {
    this.firstNameComponent = firstNameComponent;
  }

  public UIComponent getLastNameComponent() {
    return lastNameComponent;
  }

  public void setLastNameComponent(UIComponent lastNameComponent) {
    this.lastNameComponent = lastNameComponent;
  }

  private List<Person> personResults;

  private Person person;

  public James() {
    personResults = new ArrayList();
    personResults.add(new PersonBuilder(1, "Bob", "Uncle").build());
    personResults.add(new PersonBuilder(2, "Jack", "Black").build());
  }

  public List<Person> getPersonResults() {
    return personResults;
  }

  public void setPersonResults(List<Person> personResults) {
    this.personResults = personResults;
  }

  public Person getPerson() {
    return person;
  }

  public void setPerson(Person person) {
    this.person = person;
  }

  private void clearPerson() {
    person = new PersonBuilder().build();
  }

  public String gotoList() {
    return "james-list";
  }

  public String gotoAdd() {
    clearPerson();
    return "james-add";
  }

  public String cancelAdd() {
    clearPerson();
    return gotoList();
  }

  public String addPerson() {
    personResults.add(person);
    return gotoList();
  }
}

james-list.xhtml:

<?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-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en"
      xmlns:ui="http://java.sun.com/jsf/facelets"
      xmlns:f="http://java.sun.com/jsf/core"
      xmlns:h="http://java.sun.com/jsf/html">
<h:head>
  <title>list page</title>
</h:head>

<body>
<div class="container">
  <div class="content">
    <h:messages showSummary="true" showDetail="false" errorClass="error" infoClass="info"
                warnClass="warn"/>
    <h:form>
      <h:dataTable value="#{james.personResults}" var="person">
        <h:column>
          <f:facet name="header">Id</f:facet>
          <h:outputText value="#{person.id}"/>
        </h:column>
        <h:column>
          <f:facet name="header">Name</f:facet>
          <h:outputText value="#{person.firstName}"/>
        </h:column>
        <h:column>
          <f:facet name="header">Surname</f:facet>
          <h:outputText value="#{person.lastName}"/>
        </h:column>
      </h:dataTable>
      <h:panelGroup layout="block">
        <h:commandButton value="Add" action="#{james.gotoAdd}"/>
      </h:panelGroup>
    </h:form>
  </div>
</div>
<ui:debug hotkey="L" rendered="true"/>
</body>
</html>

ジェームズ-add.xhtml:

<?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-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en"
      xmlns:ui="http://java.sun.com/jsf/facelets"
      xmlns:f="http://java.sun.com/jsf/core"
      xmlns:h="http://java.sun.com/jsf/html">
<h:head>
  <title>add page</title>
</h:head>

<body>
<div class="container">
  <div class="content">
    <h:messages showSummary="true" showDetail="false" errorClass="error" infoClass="info"
                warnClass="warn"/>
    <h:form>
      <fieldset>
        <legend>Add Person</legend>
        <h:panelGrid columns="2">
          <h:outputLabel for="PersonId" value="Id:"/>
          <h:inputText id="PersonId" value="#{james.person.id}" binding="#{james.idComponent}"/>
          <h:outputLabel for="PersonFirstName" value="First Name:"/>
          <h:inputText id="PersonFirstName" value="#{james.person.firstName}" binding="#{james.firstNameComponent}"/>
          <h:outputLabel for="PersonLastName" value="Last Name:"/>
          <h:inputText id="PersonLastName" value="#{james.person.lastName}" binding="#{james.lastNameComponent}"/>
        </h:panelGrid>
        <h:panelGroup layout="block">
          <h:commandButton value="Add" action="#{james.addPerson}"/>
          <h:commandButton value="Cancel (immediate)" action="#{james.cancelAdd}" immediate="true"/>
          <h:commandButton value="Cancel" action="#{james.cancelAdd}"/>
        </h:panelGroup>
      </fieldset>
    </h:form>
  </div>
</div>
<ui:debug hotkey="L" rendered="true"/>
</body>
</html>
于 2010-04-01T09:52:45.680 に答える