Spring MVC在表单中选择的值:在表单验证错误后选择
问题内容:
我的验证表单有问题,该表单有很多不同的字段(输入文本字段,选择选项,多个选择选项…)。我已经开发了关于具有弹簧安全性的验证表单的所有逻辑源代码,但是当验证表单失败(例如,用户未填写任何内容)并再次重新加载表单时,所有输入文本字段均已正确填充,但select选项和多个选择选项已被删除,用户必须再次选择它。为什么不填写为文本字段?
这是我的观点:
<tr>
<td><form:label path="TechContactName"><spring:message code="label.techcontactname"/><sup>*</sup></form:label></td>
<td><form:input path="TechContactName" /></td>
<td><form:errors path="techContactName" cssClass="error" /></td>
</tr>
<tr>
<td><form:label path="LicenseProduct"><spring:message code="label.licenseproduct"/><sup>*</sup></form:label></td>
<td><form:select path="licenseProduct" id="selectProduct" size="6" >
<option >Option 1</option>
<option >Option 2</option>
<option >Option 3</option>
<option >Option 4</option>
<option >Option 5</option>
<option >Option 6</option>
</form:select></td>
<td><form:errors path="licenseProduct" cssClass="error" /></td>
</tr>
<tr>
<td><form:label path="DeployCountries"><spring:message code="label.deploycountries"/><sup>*</sup></form:label></td>
<td><form:select path="deployCountries" id="selectCountries" multiple="multiple" >
<option value="AT">Austria</option>
<option value="BE">Belgium</option>
<option value="DK">Denmark</option>
<option value="FI">Finland</option>
<option value="FR">France</option>
<option value="DE">Germany</option>
</form:select> </td>
<td><form:errors path="deployCountries" cssClass="error" /></td>
</tr>
而我的控制器:
@SuppressWarnings("finally")
@RequestMapping(value = "/add", method = RequestMethod.POST)
public String addLicense(@Valid @ModelAttribute(value="license") LicenseEntity license, BindingResult result, ModelMap map, HttpServletRequest request)
{
if(result.hasErrors()){
System.out.println("validation errors size..."+result.getErrorCount());
return "editLicenseList";
} else {
//all works correctly
}
}
验证失败但form:select和form:select多个失败并正确加载任何选定值的表单时,将正确填写表单输入文本字段。
提前致谢!
问题答案:
尝试使用Spring的<form:option>
标签,而不是HTML自己的<option>
标签。这将确保验证失败后该选项保持选中状态(因为Spring将设置selected
属性)。
<form:select path="licenseProduct" id="selectProduct" size="6" >
<form:option value="Option 1"/>
<form:option value="Option 2"/>
<form:option value="Option 3"/>
<form:option value="Option 4"/>
<form:option value="Option 5"/>
<form:option value="Option 6"/>
</form:select>
和
<form:select path="deployCountries" id="selectCountries" multiple="multiple" >
<form:option value="AT" label="Austria"/>
<form:option value="BE" label="Belgium"/>
<form:option value="DK" label="Denmark"/>
<form:option value="FI" label="Finland"/>
<form:option value="FR" label="France"/>
<form:option value="DE" label="Germany"/>
</form:select>