java – 在Thymeleaf中使用’select’标签和实体
发布时间:2020-05-24 01:28:45 所属栏目:Java 来源:互联网
导读:我正在创建一个带有select标签的表单,如下所示: form th:object=${version} method=post class=form-horizontal ... div class=control-group th:classappend=${#fields.hasErrors(product)} ? error
|
我正在创建一个带有select标签的表单,如下所示: <form th:object="${version}" method="post" class="form-horizontal">
...
<div class="control-group" th:classappend="${#fields.hasErrors('product')} ? 'error'">
<label class="control-label" for="product" th:text="#{version.product}">Product</label>
<div class="controls">
<select id="product" th:field="*{product}">
<option value="" th:text="#{common.select.prompt}"></option>
<option th:each="p : ${productList}" th:value="${p.id}" th:text="${p.name}"></option>
</select>
<span class="help-inline" th:errors="*{product}"></span>
</div>
</div>
...
</form>
Spring Data JPA的DomainClassConverter类有助于在我提交表单时自动将选定的id转换为实体Product.该产品也应该不为null(我在Version类的product字段中使用@NotNull. 我遇到的问题 – 当我回来编辑数据时,未选择产品. 如果我像这样修改选择(th:field和th:errors):< - ps.s.不是悲伤的笑容 <select id="product" th:field="*{product.id}">
<option value="" th:text="#{common.select.prompt}"></option>
<option th:each="p : ${productList}" th:value="${p.id}" th:text="${p.name}"></option>
</select>
<span class="help-inline" th:errors="*{product.id}"></span>
然后当我回来编辑它时它会被选中,但验证器不起作用(产品总是被实例化,即使选择的id为null). 它看起来像一个非常常见的场景(从列表中选择一个实体),但我找不到任何好看的例子.请分享秘密知识. 解决方法解决了.存在的问题是因为我没有覆盖equals()和hashCode()方法.(编辑:安卓应用网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
