Spring MVC 数据绑定和表单标签库
数据绑定是将用户输入绑定到领域模型的一种特性。作用是将 POJO 对象的属性值与表单组件的内容绑定。
数据绑定的好处:
1. 类型总是为 String 的 HTTP 请求参数,可用于填充不同类型的对象属性。
2. 当输入验证失败时,会重新生成一个 HTML 表单。
为了高效的使用数据绑定,还需要 Spring 的表单标签库。表单标签库中包含了可以用在 JSP 页面中渲染 HTML 元素的标签,为了能够使用这些标签,必须在 JSP 页面的开头处声明这个 taglib 指令
<%@taglib uri="http://www.springframework.org/tags/form" prefix="form" %>
表单标签库中的标签 每个标签都有相应的属性
可以在下载的 Springframework 中找到详细说明

标签 // 描述
form // 渲染表单元素
input // 渲染 <input type="text" /> 元素
password // 渲染 <input type="text" /> 元素
hidden // 渲染 <input type="hidden" /> 元素
textarea // 渲染 textarea 元素
checkbox // 渲染一个 <input type="checkbox" /> 元素
checkboxes // 渲染多个 <input type="checkbox" /> 元素
radiobutton // 渲染一个 <input type="radio" /> 元素
radiobuttons // 渲染多个 <input type="radio" /> 元素
select // 渲染一个选择元素
option // 渲染一个可选元素
options // 渲染一个可选元素列表
erros // 在 span 元素中渲染字段错误
form 标签
form 标签用于渲染 HTML 表单,form 标签必须利用渲染表单输入字段的其他任意标签。
1. 该标签会自动绑定来自 Model 中的一个属性值到当前 form 对应的实体对象,默认是 command 属性,此时就可以在 form 表单提里面方便的使用该对象的属性了。
2. 该标签我们在提交表单的时候使用除 GET、POST 之外的其他方法进行提交,包括 DELETE、PUT 等
一般而言仍然需要使用 action 和 method 属性,这两个属性属于 HTML 属性。
acceptCharset //
cssClass //
cssStyle //
htmlEscape //
modleAttribute // 显示 corm backing object 的模型属性名称,默认为 command
input 标签
cssClass //
cssStyle //
cssErrorClass //
htmlEscape //
path // 要绑定的属性路径
例如,下面这个 input 标签被绑定到 form backing object 的 isbn 属性
<form:input id="isbn" path="isbn" cssErrorClass="errorBox" />
将被渲染成
<input type="text" id="isbn" name="isbn" />
cssErrorClass 属性不起作用,除非 isbn 属性中有输入验证错误,并且采用同一个表单重新显示用户输入,此时会被渲染成
<input type="text" id="isbn" name="isbn" class="errorBox" />
password 标签
cssClass //
cssStyle //
cssErrorClass //
htmlEscape //
path // 要绑定的属性路径
showPassword // 表示是否应该显示或遮盖密码,默认为 false
<form:password id="pwd" path="password" cssClass="normal" />
hidden 标签
hidden 标签与 input 标签相似,只不过没有可是的外观,因此不支持 cssClass 和 cssStyle 属性
htmlEscape //
path //
<form:hidden path="productId" />
textarea 标签
textarea 基本上就是一个支持多行输入的 input 元素
cssClass //
cssStyle //
cssErrorClass //
htmlEscape //
path //
下面的 textarea 标签就是绑定到 form backing object 的 note 属性
<form:textarea path="note" tabindex="4" rows="5" cols="80" />
checkbox 标签
cssClass //
cssStyle //
cssErrorClass //
htmlEscape //
label //
path //
<form:checkbox path="outOfStock" value="Out Of Stock" />
checkboxes 标签
cssClass //
cssStyle //
cssErrorClass //
delimiter //
element //
htmlescape //
items // 用于生成 input 元素的对象的 Collection、Map 或者 Array
itemLabel //
itemValue //
path //
下面的 checkboxes 标签将 model 属性 categoryList 的内容渲染为复选框。checkboxes 标签允许进行多个选择
<form:checkboxes path="category" items="${categoryList}" />
radiobutton 标签
cssClass //
cssStyle //
cssErrorClass //
htmlEscape //
label //
path //
下面的 radiobutton 标签绑定到 newsletter 属性
Computing Now <form:radiobutton path="newsletter" value="Computing Now" /> <br />
Modern Health <form:radiobutton path="newslatter" value="Modern Health" />
radionbuttons 标签
cssClass //
cssStyle //
cssErrorClass //
delimiter //
element //
htmlEscape //
items //
itemLabel //
itemValue //
path //
下面的 radiobuttons 标签将 model 属性 categoryList 的内容渲染为单选按钮。每次只能选择一个单选按钮:
<form:radiobuttons path="category" items="${categoryList}" />
select 标签
cssClass //
cssStyle //
cssErrorClass //
htmlEscape //
items //
itemLabel //
itemValue //
path //
items 属性特别有用,因为它可以绑定到对象的 Collection、Map、Array,为 select 元素生成选项。
<form:select id="category" path="category.id" items="${categories}" itemLabel="name" itemValue="id" />
option 标签
cssClass //
cssStyle //
cssErrorClass //
htmlEscape //
<form:select id="category" path="category.id" items="${categories}" itemLabel="name" itemValue="id" >
<option value="0"> --Please select -- </option>
</form:select>
options 标签
cssClass //
cssStyle //
cssErrorClass //
htmlEscape //
items //
itemLabel //
itemValue //
errors 标签
cssClass //
cssStyle //
delimiter //
element //
htmlescape //
path //
Spring MVC 数据绑定和表单标签库的更多相关文章
- spring mvc数据绑定与表单标签库
Book类为 package org.shaoxiu; public class Book { private String id; private String name; public Book( ...
- 关于Spring MVC中的表单标签库的使用
普通的MVC设计模式中M代表模型层,V代表视图层,C代表控制器,SpringMVC是一个典型的MVC设置模式的框架,对于视图和控制器的优化很多,其中就有与控制器相结合的JSP的表单标签库. 我们先简单 ...
- SpringMVC:学习笔记(5)——数据绑定及表单标签
SpringMVC——数据绑定及表单标签 理解数据绑定 为什么要使用数据绑定 基于HTTP特性,所有的用户输入的请求参数类型都是String,比如下面表单: 按照我们以往所学,如果要获取请求的所有参数 ...
- springmvc表单标签库的使用
springmvc中可以使用表单标签库,支持数据绑定,用来将用户输入绑定到领域模型. 例子来源<Servlet.JSP和SpringMVC学习指南> 项目代码 关键代码及说明 bean对象 ...
- spring mvc:练习:表单验证(javaConfig配置和注解)
使用Spring表单标签, 表单验证使用 JSR303 的验证注解,hibernate-validators,提供了使用MessageSource和访问静态资源(如CSS,JavaScript,图片) ...
- Spring MVC实现防止表单重复提交(转)
Spring MVC拦截器+注解方式实现防止表单重复提交
- Spring mvc之提交表单
表单内容: <body> <form action="user/login"> <table> <tr> <td>用户名 ...
- Spring MVC(十)--通过表单序列化传递参数
通过表单序列化传递参数就是将表单数据转化成字符串传递到后台,序列化之后参数请求变成这种模式param1=value1&¶m2=value2,下面用代码实现. 1.创建表单 &l ...
- Spring MVC中 提交表单报错400
背景: 在写SpringMVC表单提交的代码的时,在最后点击提交的时候总是会出现400的错误 原因: 主要原因就是表单提交的数据和对应实体类的属性无法完全匹配 解决方案: 查看我们提交的数据是否完全和 ...
随机推荐
- Java的学习03
今天依然记录一下,学习情况,可以看到自己每一天都在进步. import java.text.DateFormat; import java.text.ParseException; import ja ...
- 第三章,DNA序列的进化演变
31.前言 3.1.两个序列间的核苷酸差异 来自同一祖先序列的两条后裔序列,之间的核苷酸的差异随着时间的增加而变大.简单的计量方法,p距离 3.2.核苷酸代替数的估计 3.3.Jukes和Cantor ...
- 【scrapy_redis】调试后爬取了部分数据,然后重新调试时,直接被去重机制过滤掉无法重头开始爬取
这2天遇到一个问题,之前调试的时候爬取了一些数据,结果第二天重新调试的时候发现爬虫很快结束,而且还没有报错.后来从日志里看到这个: no more duplicates will be shown ( ...
- SQL%ROWCOUNT作用
SQL%ROWCOUNT是一个游标属性,而SQL中的DML操作实际上是一种隐式的游标操作,在做insert,update,delete,merge以及select into操作时,Oracle会打开一 ...
- 矩形覆盖(python)
题目描述 我们可以用2*1的小矩形横着或者竖着去覆盖更大的矩形.请问用n个2*1的小矩形无重叠地覆盖一个2*n的大矩形,总共有多少种方法? # -*- coding:utf-8 -*- class S ...
- rdlc报表的导出及预览时表头
感谢各路大神的博客,总结rdlc报表中目前用到的知识,积累. 一.rdlc报表PDF打印出现空白页 1.先至Report.rdlc報表設計的頁面,選擇功能表上的[報表]->[報表屬性],在[配置 ...
- http://www.rabbitmq.com/documentation.html
http://www.rabbitmq.com/documentation.html https://www.gitbook.com/book/geewu/rabbitmq-quick/details
- vue 返回上一页后,上一页由参数渲染的内容无法显示
思路1:将参数传递给第二个页面后,返回上一页时,再讲参数传回第一页(此方法适用于层级少的)(亲测有效) 思路2:将参数放到全局变量中(还未尝试过)
- 【校招面试 之 C/C++】第32题 C++ 11新特性(三)之for关键字
1.for循环的一般写法: int arr[10] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 }; for (int i = 0; i < 10; i++) cout ...
- stark组件之pop操作【模仿Django的admin】
一.先看下什么django的admin的pop到底是个什么东西 其实就是这么一个东西, a.在添加页面,在一对多和多对多的项后加了一个+号 b.点击这个加号,会弹出对应的添加 页面,在新的添加 c.添 ...