我尝试在 Spring Boot 的下拉列表中保留数据库中的值, thymeleaf 但数据库中填充了空值。
显然控制器没有传递该值。
虽然我可以在 GET 中获取并显示值,但我无法将其保留在 POST 中。< / p>
我无法从任何地方获得明确的示例,甚至 Thymeleaf 上的示例也不清楚。
请提供一些好的示例或解决方案。
代码如下。
@Controller
public class HomeController {
@RequestMapping(value = "/signup", method = RequestMethod.POST)
public String signupPost(@ModelAttribute("user") User user,
Model model, BindingResult result) {
if (!result.hasErrors()) {
userService.saveUser(user);
}
return "redirect:/";
}
}
User
类如下
@Entity
public class User {
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
@Column(name = "user_id", nullable = false, updatable = false)
private Long userId;
@ManyToOne(fetch = FetchType.EAGER, cascade = CascadeType.ALL)
@JoinColumn(name = "award_partner_id")
private AwardPartner awardPartner;
getters and setters....
}
HTML代码段位于:
<!--Award Partner-->
<div class="form-group">
<label class="col-md-4 control-label">Award Partner</label>
<div class="col-md-6 selectContainer">
<div class="input-group">
<span class="input-group-addon"><i
class="glyphicon glyphicon-list"></i></span>
<select name="awardPartner" roleId="awardPartner" id="awardPartner"
th:field="*{awardPartner}" class="form-control selectpicker">
<option value="">Select Award Partner</option>
<option th:each="awardPartner : ${awardPartners}"
th:value="${awardPartner.id}"
th:text="${awardPartner.title}"></option>
</select>
</div>
</div>
</div>
<!-- end snippet -->
答案 0 :(得分:1)
在您的表单标记中,我认为有th:object="user"
。
在您的选择标记中,有th:field="*{awardPartner}"
。这意味着您将所选值(所选选项标记的值)放在对象用户的字段awardPartner中。此字段awardPartner
的类型为AwardPartner
在选项值中,您有一个id(int或string?)作为值,但不是AwardPartner
类型的对象