我是Spring的新手我有一个页面addContact,因为我从以下方式获取数据库中的dropDown数据
@RequestMapping("/addContact")
public ModelAndView registerContact(@ModelAttribute Contact contact) {
List<ContactType> contactTypeList = contactdao.getContactTypeList();
Map<Integer,String> contactTypeSelect = new LinkedHashMap<Integer,String>();
Iterator<ContactType> iterator = contactTypeList.iterator();
while (iterator.hasNext()) {
ContactType ct = iterator.next();
contactTypeSelect.put(ct.getContactTypeId(),ct.getContactTypeName());
}
Map<String, Object> map = new HashMap<String, Object>();
map.put("contactTypeSelect", contactTypeSelect);
return new ModelAndView("addContact", "map", map);
}
Run Code Online (Sandbox Code Playgroud)
现在要将数据插入数据库,我有以下方法,
@RequestMapping("/insert")
public String insertData(@Valid Contact contact, BindingResult result, HttpServletRequest request ) {
if (result.hasErrors()) {
return "addContact";
}
else {
HttpSession session = request.getSession();
session.setAttribute("path", request.getSession().getServletContext().getRealPath("/WEB-INF"));
if (contact != null){
contactService.insertData(contact,request);
}
return "redirect:/getList";
}
Run Code Online (Sandbox Code Playgroud)
}
当验证失败时,下拉数据会丢失(这很明显),实现验证的正确方法是什么.
创建一个带注释的方法,@ModelAttribute用于加载引用数据.将在每个@RequestMapping方法之前调用此方法.
@ModelAttribute("contactTypeSelect")
public List<ContactType> registerContact() {
return contactdao.getContactTypeList();
}
Run Code Online (Sandbox Code Playgroud)
在表单中,您可以使用<form:select ../>标记来呈现itemValue和itemLabel.
<form:select items="${contactTypeSelect}" itemLabel="contactTypeName" itemValue="contactTypeId" />
Run Code Online (Sandbox Code Playgroud)
有了这个,您可以将您的addContact方法重构为以下内容
@RequestMapping("/addContact")
public String registerContact(@ModelAttribute Contact contact) {
return "addContact";
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
1543 次 |
| 最近记录: |