我可以动态添加JSF组件吗?我需要一个带有按钮的表单,该表单应该向表单添加一个<h:inputText>
。这可能吗?
我知道这应该可以在JavaScript中以某种方式实现。有人知道如何在JSF中这样做吗?我认为主要问题是如何通过#{value}
获取或设置新输入的值。
答案 0 :(得分:31)
使用<h:dataTable>
或<ui:repeat>
等迭代组件来显示动态大小List
的实体。使bean @ViewScoped
确保在同一视图上的回发中记住列表,而不是一遍又一遍地重新创建。
<h:dataTable>
的启动示例:
<h:form>
<h:dataTable value="#{bean.items}" var="item">
<h:column><h:inputText value="#{item.value}" /></h:column>
<h:column><h:commandButton value="remove" action="#{bean.remove(item)}" /></h:column>
</h:dataTable>
<h:commandButton value="add" action="#{bean.add}" />
<h:commandButton value="save" action="#{bean.save}" />
</h:form>
管理bean:
@ManagedBean
@ViewScoped
public class Bean {
private List<Item> items;
@PostConstruct
public void init() {
items = new ArrayList<Item>();
}
public void add() {
items.add(new Item());
}
public void remove(Item item) {
items.remove(item);
}
public void save() {
System.out.println("items: " + items);
}
public List<Item> getItems() {
return items;
}
}
型号:
public class Item {
private String value;
public String getValue() {
return value;
}
public void setValue(String value) {
this.value = value;
}
public String toString() {
return String.format("Item[value=%s]", value);
}
}
答案 1 :(得分:1)
它应该是那样的
将表单标记绑定到bean属性
<form binding="#{myBean.myform}">...</form>
@ManagedBean("myBean")
public class Bean{
property HtmlForm myform;
}
on event,创建输入组件的新实例
HtmlInputText input=new HtmlInputText();
并附加到您的表单
myform.getChildren().add(input);
答案 2 :(得分:0)
使用h:dataTable
动态添加元素...拥有您想为dataTable提供值的任何类型的列表......
在h:dataTable
...中,您可以包含要在<h:column>
它将用于生成您想要动态创建的元素。