【问题标题】:How to handle form submission in HTML5 + Thymeleaf如何在 HTML5 + Thymeleaf 中处理表单提交
【发布时间】:2015-09-03 11:59:56
【问题描述】:

我必须提交一个包含大约 30 个输入参数(文本、选择、日期选择器)的表单。这些字段映射到两个类。如何映射每个字段以获取控制器中的值。

HTML:

<form id="searchPersonForm" action="#" th:object="${person}" method="post">
<input type="text" class="form-control" id="person_id" th:field="*{person_id}"></input>
<input type="text" class="form-control" id="child_id" th:field="*{child_id}"></input>
</form>

控制器:

    @RequestMapping(value = "/search", method = RequestMethod.POST)
    public String searchQuotation(Person person){

    // Some validation
    return "SearchPerson";
    }

Person.java:

@Entity
@Table(name = "PERSON")
public class Person implements java.io.Serializable {

    @SequenceGenerator(name = "p_id_generator", sequenceName = "PERSON_SEQ", allocationSize = 1)
    @Id
    @GeneratedValue(strategy = GenerationType.AUTO, generator = "p_id_generator")
    private Long person_id;

    public Long getPerson_id() {
        return person_id;
    }

    public void setPerson_id(Long person_id) {
        this.person_id = person_id;
    }
}   

子:java:

public class Child { 

    private Long child_id;

    public Long getChild_id() {
        return child_id;
    }

    public void setChild_id(Long child_id) {
        this.child_id = child_id;
    }
}   

这样我可以从 Person 对象访问 person_id。但是如何访问child_id。

我的应用程序在 Spring 启动中使用 HTML5+Thymeleaf。

任何人都可以帮助解决这个问题。 谢谢。

【问题讨论】:

    标签: html forms spring-boot thymeleaf


    【解决方案1】:

    我相信您的问题可能分为两部分,我会尽力回答这两个部分。首先在表单本身上,您将如何获得 child_id 以显示表单上另一个对象的字段。由于您的 Person 类没有 Child 关系,因此您需要有 2 个对象。因此,如果您提供表单的第一个控制器如下所示:

    @RequestMapping("/")
    public String home(Map<String, Object> model) {
        Person person = new Person();
        person.setPerson_id((long)3);
        Child child = new Child();
        child.setChild_id((long)4);
        model.put("person", person);
        model.put("child", child);
        return "home";
    }
    

    然后您的表单将如下所示显示对象中的每个值。

    <form id="searchPersonForm" action="/search" th:object="${person}" method="post">
        <input type="text" class="form-control" id="person.person_id" th:field="*{person_id}"></input>
        <input type="text" class="form-control" id="child.child_id" th:field="${child.child_id}"></input>
        <input type="submit">Submit</input>
    </form>
    

    Thymeleaf site 上有一些有用的文档,解释了 th:object 标记如何与范围内的其他表达式交互。在这种情况下,您需要使用 $ 语法直接引用子节点。

    在接收端,您需要实现一个控制器来拥有 2 个对象。正如您可能注意到的那样,我将您的表单更改为表单字段的 id 具有对象前缀。因此,如果您的控制器方法如下所示:

    @RequestMapping(value = "/search", method = RequestMethod.POST)
    public String searchQuotation(Person person, Child child){
    
        System.out.println("person_id=" + person.getPerson_id());
        System.out.println("child_id=" + child.getChild_id());
        // Some validation
        return "SearchPerson";
    }
    

    您将在服务器端看到这些值。如果这回答了您的问题,请告诉我。

    【讨论】:

    • 非常感谢。我会试试这个解决方案
    • 完美运行。谢谢