如何动态添加JSF组件

时间:2010-08-04 19:22:33

标签: jsf jsf-2 dynamic-forms

我可以动态添加JSF组件吗?我需要一个带有按钮的表单,该表单应该向表单添加一个<h:inputText>。这可能吗?

我知道这应该可以在JavaScript中以某种方式实现。有人知道如何在JSF中这样做吗?我认为主要问题是如何通过#{value}获取或设置新输入的值。

3 个答案:

答案 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>

内创建的元素标记

它将用于生成您想要动态创建的元素。