あなたが望むすべてを行うことが可能です。
既存のコントロールを使用して、必要なものに近いものを構築できます。JSF を最大限に活用するための良い方法は、ビューに合わせてモデルを調整することです。たとえば、このビューには、データ テーブルに値を追加できる編集オプションが表示されます。
<f:view>
<h:form>
<h:dataTable value="#{people.list}" var="row">
<h:column>
<f:facet name="header">
<h:outputText value="#" />
</f:facet>
<h:selectBooleanCheckbox value="#{row.selected}" />
</h:column>
<h:column>
<f:facet name="header">
<h:outputText value="First Name" />
</f:facet>
<h:inputText value="#{row.firstname}" />
</h:column>
<h:column>
<f:facet name="header">
<h:outputText value="Last Name" />
</f:facet>
<h:inputText value="#{row.lastname}" />
</h:column>
<f:facet name="footer">
<h:panelGroup>
<h:commandButton value="Add Row" action="#{people.addPerson}" />
<h:commandButton value="Delete Selected"
action="#{people.deleteSelected}" />
<h:commandButton value="Finish" action="#{people.finish}" />
</h:panelGroup>
</f:facet>
</h:dataTable>
</h:form>
</f:view>
ピープル豆:
public class People implements Serializable {
private static final long serialVersionUID = 1L;
private List<Person> people = new ArrayList<Person>();
public People() {
// initialise with one entry
people.add(new Person());
}
public List<Person> getList() {
return people;
}
public String addPerson() {
people.add(new Person());
return null;
}
public String deleteSelected() {
Iterator<Person> entries = people.iterator();
while (entries.hasNext()) {
Person person = entries.next();
if (person.isSelected()) {
entries.remove();
}
}
return null;
}
public String finish() {
System.out.println(people);
return "someNavigationRule";
}
}
人豆:
public class Person implements Serializable {
private static final long serialVersionUID = 1L;
private String firstname;
private String lastname;
private transient boolean selected = false;
public String getFirstname() {
return firstname;
}
public void setFirstname(String firstname) {
this.firstname = firstname;
}
public String getLastname() {
return lastname;
}
public void setLastname(String lastname) {
this.lastname = lastname;
}
public boolean isSelected() {
return selected;
}
public void setSelected(boolean selected) {
this.selected = selected;
}
}
顔-config.xml:
<managed-bean>
<managed-bean-name>people</managed-bean-name>
<managed-bean-class>addmultiple.People</managed-bean-class>
<managed-bean-scope>session</managed-bean-scope>
</managed-bean>
このアプローチは非常に柔軟で、一部の CSS を使用すると見栄えがよくなります。ビューとモデルにいくつかの変更を加えると、たとえば、最後の行のみを編集可能にすることができます。
結果のエクスペリエンスが十分にリッチでない場合、または再利用できるものが必要な場合は、カスタム コントロールを作成できます。何が欲しいかを正確に知らずに詳細に入るのは難しいですが、おそらく次のものが必要になるでしょう:
- HTML を送信し、フォーム リクエストをデコードするための新しいRenderer 。
- (おそらく) 新しいcomponent、おそらくUIDataを拡張したもの、およびレンダーキット固有の (HTML などの) 属性を公開するための具体的なフォーム。
- コントロールを JSP で使用できるようにするための新しい JSPタグ クラス。
- 上記のすべての定義は、faces-config.xml にあります(仕様を参照)。