表单数据回显
一. 概念:
在数据提交出现错误的时候, 已填写的信息仍在文本框中, 比如用户登录, 当用户输入错误的密码之后, 用户名仍在文本框, 只是密码框清空
二. 意义:
对于一些要填写很多信息的表单, 如果因为一些错误导致已经填写的整个表单信息重新填写, 对于用户非常地不友好
三. 回显方法:
1. 默认情况
POJO数据传入controller方法后, springMvc自动将POJO数据放到request域, key等于POJO类的首字母小写
** 实验:
(1) 在商品名称填错的情况下, 点击"提交"按钮, 其他数据仍在[注意, POJO类:ItemsCustom, 在jsp页面取值形式:value="${itemsCustom.name }"]
(2) 修改Handler的响应POJO类的key[属性]
// 商品信息修改页面的展示 @RequestMapping("/editItems") public String editItems(Model model, Integer id) throws Exception { // 根据id获取商品信息 ItemsCustom itemsCustom = itemsService.findItemsById(id); model.addAttribute("items", itemsCustom); // 改之前是itemsCustom return "items/editItems"; }
页面获取数据的形式
1 <table border="1" cellpadding="5" cellspacing="1" style="width: 30%"> 2 <tr> 3 <td>商品名称</td> 4 <td> 5 <input type="text" name="name" value="${items.name }"/> 6 </td> 7 </tr> 8 <tr><td>商品价格</td><td><input type="text" name="price" value="${items.price }"/></td></tr> 9 <tr><td>生产日期</td> 10 <td> 11 <input type="text" name="createtime" value='<fmt:formatDate value="${items.createtime }" pattern="yyyy-MM-dd HH:mm:ss"/>' 12 class="laydate-icon" οnclick="laydate()"/> 13 </td> 14 </tr> 15 <tr><td>商品描述</td><td><textarea rows="3" cols="40" name="detail">${items.detail }</textarea></td></tr> 16 </table>
在这种情况下, Handler可以正常向jsp页面响应数据, 但是由于传递的key值是items, 不等于POJO类ItemsCustom的首字母小写, 当商品名称填写出错时
无法进行数据回显, 数据全部消失, 需要重新填写, 如下:
2. 非默认情况下的数据回显解决方法
插入一个知识点: @ModelAttribute这个注解还可以将方法的返回值响应到页面
Handler代码:
1 // 模拟@ModelAttribute注解将方法的返回值响应到页面的试验[静态数据] 2 @ModelAttribute("itemsTypes") 3 public Map<String, String> getItemsTypes() { 4 Map<String, String> itemsTypes = new HashMap<String, String>(); 5 // 静态数据, 开发中要去数据库获取 6 itemsTypes.put("101", "数码"); 7 itemsTypes.put("102", "母婴"); 8 itemsTypes.put("103", "家电"); 9 return itemsTypes; 10 }
jsp代码:
1 <td style="width: 190px"> 商品类型: 2 <select name="types" style="width: 100px"> 3 <c:forEach items="${itemsTypes }" var="type"> 4 <option value="${type.key }">${type.value }</option> 5 </c:forEach> 6 </select> 7 </td>
运行:
因此, 做一个实验: 注明(静态数据)
在"提交"按钮对应的Handler方法中, 添加注解@ModelAttribute("items"), 里面的key值, 刚好是jsp页面用于取值的key, 这时候可以进行数据回显
除此之外, 对于数据回显, 还有比添加@ModelAttribute注解方法更简单的方法, 那就是: 直接将要回显的数据放入Model中
但是对于简单类型的属性, springMvc不支持回显, 只能通过Model方法实现: model.addAttribute("id", id);
总结数据回显的方法:
1. 使用springMvc默认的方法, 保持jsp中取值的key和POJO类名的首字母小写一致;
2. 使用@ModelAttribute注解, jsp中取值的key和POJO类名的首字母小写可以不一致;
3. 使用Model, 直接将数据放入Model对象中
本文作者:TwcatL_tree
本文链接:https://www.cnblogs.com/twcat/p/16912656.html
版权声明:本作品采用知识共享署名-非商业性使用-禁止演绎 2.5 中国大陆许可协议进行许可。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步