e### form标签简介
srpingmvc中的form标签只是restful风格的请求访问,使用这个form标签应该保证有数据的回传,也就是说,它一出来就要展示数据的。就是所谓的回显功能。
使用步骤
1、引入标签库(在JSP中):
<%@ taglib uri="http://www.springframework.org/tags/form" prefix="form"%>
2、网页显示代码:
form标签中的一些属性:
path:表示对象的那个属性
label:表示要显示出来的信息
items:一个作用域中的对象,下面是用部门这个实体来作为对象
itemValue:表示选项的id值
itemLabel:表示选项里展示出来的数据
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>
<%@ taglib uri="http://www.springframework.org/tags/form" prefix="form"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
<!-- modelAttribute=""自定义回显对象的属性名 -->
<form:form action="emp" method="post" modelAttribute="emp">
<c:if test="${empty emp.id }" var="flag"></c:if>
<c:if test="${!flag }">
<form:hidden path="id"/>
<input type="hidden" name="_method" value="PUT">
</c:if>
<table border="1" style="text-align: center">
<tr>
<th colspan="2">
<c:if test="${!flag }">修改员工信息</c:if>
<c:if test="${flag }">添加员工信息</c:if>
</th>
</tr>
<tr>
<td>LASTNAME</td>
<td>
<form:input path="lastName"/>
</td>
</tr>
<tr>
<td>EMAIL</td>
<td>
<form:input path="email" />
</td>
</tr>
<tr>
<td>GENDER</td>
<td>
<form:radiobuttons path="gender" items="${genders }"/>
</td>
</tr>
<tr>
<td>DEPARTMENT</td>
<td>
<form:select path="department.id" items="${depts }" itemLabel="departmentName" itemValue="id"></form:select>
</td>
</tr>
<tr>
<td colspan="2">
<c:if test="${!flag }">
<input type="submit" value="UPDATE"/>
</c:if>
<c:if test="${flag }">
<input type="submit" value="ADD"/>
</c:if>
</td>
</tr>
</table>
</form:form>
</body>
</html>
更新数据页面回显:
controller层代码
@RequestMapping(value="emp",method = RequestMethod.GET)
public String add(Map<String, Object> map) {
Collection<Department> depts = departmentDao.getDepartments();
//创建存储性别gender的信息
Map<String, String> genders = new HashMap<String, String>();
genders.put("0","女");
genders.put("1","男");
map.put("depts", depts);
map.put("genders", genders);
//form标签有自动回显的功能,会在页面中能够默认获取request作用域中的command属性的值(如果有自定义的值就写具体自定义的值)
map.put("emp", new Employee());
return "edit";
}
/*
* 添加员工信息
*/
@RequestMapping(value="emp",method = RequestMethod.POST)
public String addEmp(Employee emp) {
employeeDao.save(emp);
return "redirect:/emps";
}
/**
* 回显功能
*/
@RequestMapping(value="emp/{id}",method = RequestMethod.GET)
public String toupdate(@PathVariable("id")Integer id,Map<String, Object> map) {
//获取要修改的员工信息
Employee employee = employeeDao.get(id);
//获取所有的部门信息,给用户选择
Collection<Department> department = departmentDao.getDepartments();
Map<String, String> genders = new HashMap<String, String>();
genders.put("0","女");
genders.put("1","男");
map.put("genders", genders);
map.put("emp", employee);
map.put("depts", department);
return "edit";
}
@RequestMapping(value="emp/{id}",method = RequestMethod.PUT)
public String update(Employee employee) {
employeeDao.save(employee);//修改
return "redirect:/emps";
}
使用Spring的表单标签
1) 通过 SpringMVC 的表单标签可以实现将模型数据中的属性和 HTML 表单元素相绑定,以实现表单数据更便捷编辑和表单值的回显
2) form 标签
- 一般情况下,通过 GET 请求获取表单页面,而通过 POST 请求提交表单页面,因此获取表单页面和提交表单页面的 URL 是相同的。
- 只要满足该最佳条件的契约,form:form 标签就无需通过 action 属性指定表单提交的 URL
- 可以通过 modelAttribute 属性指定绑定的模型属性,若没有指定该属性,则默认从 request 域对象中读取 command 的表单 bean,如果该属性值也不存在,则会发生错误。
3) SpringMVC 提供了多个表单组件标签,如 < form:input/>、< form:select/> 等,用以绑定表单字段的属性值,它们的共有属性如下:
-
path:表单字段,对应 html 元素的 name 属性,支持级联属性
-
htmlEscape:是否对表单值的 HTML 特殊字符进行转换,默认值为 true
-
cssClass:表单组件对应的 CSS 样式类名
-
cssErrorClass:表单组件的数据存在错误时,采取的 CSS 样式
4) form:input、form:password、form:hidden、form:textarea:对应 HTML 表单的 text、password、hidden、textarea 标签
5) form:radiobutton:单选框组件标签,当表单 bean 对应的属性值和 value 值相等时,单选框被选中
6) form:radiobuttons:单选框组标签,用于构造多个单选框
- items:可以是一个 List、String[] 或 Map
- itemValue:指定 radio 的 value 值。可以是集合中 bean 的一个属性值
- itemLabel:指定 radio 的 label 值
- delimiter:多个单选框可以通过 delimiter 指定分隔符
7) form:checkbox:复选框组件。用于构造单个复选框
8) form:checkboxs:用于构造多个复选框。使用方式同 form:radiobuttons 标签
9) form:select:用于构造下拉框组件。使用方式同 form:radiobuttons 标签
10) form:option:下拉框选项组件标签。使用方式同 form:radiobuttons 标签
11) form:errors:显示表单组件或数据校验所对应的错误
- <form:errors path= “*” /> :显示表单所有的错误
- <form:errors path= “user*” /> :显示所有以 user 为前缀的属性对应的错误
- <form:errors path= “username” /> :显示特定表单对象属性的错误