Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/java/388.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java thymeleaf中的嵌套对象_Java_Thymeleaf - Fatal编程技术网

Java thymeleaf中的嵌套对象

Java thymeleaf中的嵌套对象,java,thymeleaf,Java,Thymeleaf,我正在尝试使用thymeleaf构建一个表单,我的实体包括对象的集合(列表)。我正在努力为这个案子建立一个合适的形式 这是我的实体: @Entity public class Owner { @Id @GeneratedValue private int id; @Column(name = "first_name") private String firstName; @Column(name = "last_name") privat

我正在尝试使用thymeleaf构建一个表单,我的实体包括对象的集合(列表)。我正在努力为这个案子建立一个合适的形式

这是我的实体:

@Entity
public class Owner {

    @Id
    @GeneratedValue
    private int id;
    @Column(name = "first_name")
    private String firstName;
    @Column(name = "last_name")
    private String lastName;

    @OneToMany(cascade = CascadeType.ALL, mappedBy = "owner")
    private List<Phone> phones;
    @OneToMany(cascade = CascadeType.ALL, mappedBy = "owner")
    private List<Pet> pets;

//getterss and setters
这是我用来构建表单的html文件:

<!DOCTYPE html>
<html xmlns:th="http:/www.thymealeaf.org">
<head>
<meta charset="ISO-8859-1"></meta>
<title>Add new owner to database</title>
</head>
<body>
    <div id="form">
        <form th:action="@{/addOwner.do}" th:object="${Owner}" method="post">

            <label for="firstName">First Name: </label> 
            <input type="text" th:field="*{firstName}" /> 

            <label for="lastName">Last Name:</label>
            <input type="text" th:field="*{lastName}" /> 

            <!-- Here is the core problem -->
            <label for="pets">Pet Name: </label>
            <input type="text" th:each="pet : *{pets}"/> 

            <input type="submit" value="add" />
        </form>
    </div>
</body>

将新所有者添加到数据库
名字:
姓氏:
宠物名:
所以我在努力解决这个问题:

 <!-- Here is the core problem -->
                <label for="pets">Pet Name: </label>
                <input type="text" th:each="pet : *{pets}"/> 

宠物名:
我的问题是,我不知道如何访问表单内部列表集合中的Pet对象,以便输入petName属性


//编辑,或者可能有不同的方法?最明显的方法是从表单中获取字符串,然后在控制器中将字符串构建为宠物名,然后再将对象添加到数据库中?

您可以尝试一下,并告诉我这是否对您有效吗

<div th:each="pet, stat : *{pets}"> 
   <input type="text" th:field="*{pet[__${stat.index}__].petName}" /> 
</div>


它不起作用,这个解决方案没有“输入字段”,我用宠物名解决了这个问题:这只允许插入一只宠物,这使得相关的一只宠物变得毫无用处,然而这里最好的解决方案是使用java脚本动态生成表单,这样我们就可以单击“添加下一只宠物”在同一页上-我猜,所以我现在就不看了。你不想在列表中显示生成的宠物吗?不,它是数据库的输入表单,我不想查看实体的属性,只需创建一个并保存到数据库
<div th:each="pet, stat : *{pets}"> 
   <input type="text" th:field="*{pet[__${stat.index}__].petName}" /> 
</div>