SpringMVC的表单form标签、表单回显

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” /> :显示特定表单对象属性的错误
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SpringMVC中,表单的处理是非常常见的操作。而SpringMVC提供了form:标签库来简化表单的处理,使得表单的处理更加方便和简单。 使用form:标签库,需要在JSP页面中引入form标签库的命名空间,如下所示: ``` <%@ taglib prefix="form" uri="http://www.springframework.org/tags/form" %> ``` 引入命名空间后,就可以使用form标签库提供的标签来处理表单了。比如,使用form:form标签创建一个表单,如下所示: ``` <form:form modelAttribute="user" method="post" action="/user/save"> <table> <tr> <td><form:label path="username">Username:</form:label></td> <td><form:input path="username" /></td> </tr> <tr> <td><form:label path="password">Password:</form:label></td> <td><form:password path="password" /></td> </tr> <tr> <td colspan="2"><input type="submit" value="Submit" /></td> </tr> </table> </form:form> ``` 在上面的代码中,form:form标签用来创建一个表单,其中modelAttribute属性用来指定表单数据绑定到的对象,method属性用来指定表单提交时使用的HTTP方法,action属性用来指定表单提交的URL。form:label标签用来创建一个标签,path属性用来指定标签绑定到的对象属性,form:input标签用来创建一个文本框,path属性用来指定文本框绑定到的对象属性,form:password标签用来创建一个密码框,path属性用来指定密码框绑定到的对象属性。 使用form:标签库可以非常方便地处理表单,提高开发效率。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值