包含inputText的DataTable:可以使用JSF Custom Component

9 java jsf

我是JSF的新手,对于应用程序我很担心我要做多字段输入表单.

简而言之,用户在输入数据时应该有一个inputText和一个添加新输入文本以便输入另一个数据的"添加"按钮.用户完成后,他会按下另一个提交按钮.我找了一些已经完成的东西,但我没有找到任何东西,所以我决定创建自己的自定义jsf组件

我们的想法是创建一个组件,该组件包含dataTable,其中包含datatable中每行的inputText,以及一个向绑定到数据表的集合添加行的按钮.

我正在查看jsf文档和书籍,但我有点困惑,我不确定是否有可能创建这样的组件...有人可以帮助我吗?TIA

McD*_*ell 12

可以做你想做的一切.


您可以使用现有控件构建与您想要的内容接近的内容.充分利用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>
Run Code Online (Sandbox Code Playgroud)

人豆:

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";
    }

}
Run Code Online (Sandbox Code Playgroud)

人豆:

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;
    }

}
Run Code Online (Sandbox Code Playgroud)

faces-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>
Run Code Online (Sandbox Code Playgroud)

这种方法非常灵活,有些CSS,看起来相当不错.例如,对视图和模型进行一些更改后,您可以只将最后一行编辑为可编辑状态.


如果结果体验不够丰富,或者您需要可以重复使用的内容,则可以创建自定义控件.如果不确切知道自己想要什么,很难进入细节,但您可能需要:

  1. 用于发出HTML和解码形式请求的新渲染器.
  2. (可能)一个新组件,可能扩展了UIData,以及一个用于公开特定于renderkit的(例如HTML)属性的具体形式.
  3. 一个新的JSP 标记类,用于允许在JSP中使用该控件.
  4. faces-config.xml中所有上述内容的定义(请参阅规范).