Java之Spring MVC中表单标签的简介说明
Spring MVC中表单标签的功能:将JSP页面渲染出相应的HTML元素,使浏览器可正常显示信息。
Spring MVC使用注意事项:
JSP中Spring MVC标签需在头部使用taglib声明,如下所示:
<%@ taglib prefix="form" uri="http://www.springframework.org/tags/form"%>
常见的Spring MVC如下所示:
名称 | 作用 |
---|---|
form | 渲染一个html表单元素 |
input | 渲染一个html <input type="text"/> 元素 |
password | 渲染一个html<input type="password"/> 元素 |
hidden | 渲染一个html<input type="hidden"/> 元素 |
textarea | 渲染一个htmltextarea 元素 |
checkbox | 渲染一个html<input type="checkbox"/> 元素 |
checkboxes | 渲染一个html<input type="checkbox"/> 元素 |
radiobutton | 渲染一个html<input type="radio"/> 元素 |
radiobuttons | 渲染一个html包含多个 <input type="radio"/> 元素 |
select | 渲染一个html select选择元素 |
option | 渲染一个html中select中选项元素 |
options | 渲染多个选项元素 |
errors | 在span元素中渲染字段错误 |
form表单标签
表单标签的语法格式如下:<form:form ModelAttribute="xxx" method="post" action="xxx">
...
</form:form>
- acceptCharset:定义服务器接受的字符编码列表。
- commandName:暴露表单对象的模型属性名称,默认为 command。
- cssClass:定义应用到 form 元素的 CSS 类。
- cssStyle:定义应用到 form 元素的 CSS 样式。
- htmlEscape:true 或 false,表示是否进行 HTML 转义。
- modelAttribute:暴露 form backing object 的模型属性名称,默认为 command。
commandName 和 modelAttribute 属性的功能基本一致,
用于绑定一个 JavaBean 对象。
如:控制器类 UserController 的方法
inputUser 是返回 userAdd.jsp 的请求处理方法
inputUser 方法如下:
@RequestMapping(value="/input") public String inputUser(Model model) { ... model.addAttribute("user", new User()); return "userAdd"; }
userAdd.jsp中内容如下:
<form:form modelAttribute="user" method="post" action="user/save">
...
</form:form>
当inputUser方法中,没有 Model 属性 user,userAdd.jsp 页面就会抛出异常,
由于表单标签无法找到在其 modelAttribute 属性中指定的 form backing object。
input 标签
input 标签的语法格式如下:<form:input path="xxx"/>
该标签除了有 cssClass、cssStyle、htmlEscape 属性以外还有一个最重要的属性——path
path 属性的功能:
将文本框输入值绑定到 form backing object 的一个属性。
如下:
<form:form modelAttribute="user" method="post" action="user/save">
<form:input path="userName"/>
</form:form>
password 标签
password 标签的语法格式如下:<form:password path="xxx"/>
此标签同input标签用法相同,只是显示不同hidden 标签
hidden 标签的语法格式如下:<form:hidden path="xxx"/>
此标签同input标签用法相同,只是显示不同由于此标签无需显示,所以此标签不支持cssClass及cssStyle属性
textarea 标签
textarea 基本上就是一个支持多行输入的 input 元素,语法格式如下:<form:textarea path="xxx"/>
此标签同input标签用法相同,只是显示不同checkbox 标签
checkbox 标签的语法格式如下:<form:checkbox path="xxx" value="xxx"/>
多个 path 相同的 checkbox 标签,它们是一个选项组,允许多选,选项值绑定到一个数组属性。如下:
<form:checkbox path="friends" value="张三"/>张三
<form:checkbox path="friends" value="李四"/>李四
<form:checkbox path="friends" value="王五"/>王五
<form:checkbox path="friends" value="赵六"/>赵六
此标签的其它用法同input标签相同
checkboxes 标签
checkboxes 标签渲染多个复选框,是一个选项组,相当于多个 path 相同的 checkbox 标签。此标签拥有3 个非常重要的属性,即 items、itemLabel 和 itemValue
- items:用于生成 input 元素的 Collection、Map 或 Array。
- itemLabel:items 属性中指定的集合对象的属性,为每个 input 元素提供 label。
- itemValue:items 属性中指定的集合对象的属性,为每个 input 元素提供 value。
checkboxes 标签的语法格式如下:
<form:checkboxes items="xxx" path="xxx"/>
如下:<form:checkboxes items="${chklist}" path="chkList"/>
上述示例代码是将 model 属性 chkList的内容(集合元素)渲染为复选框。在 itemLabel 和 itemValue 省略的情况下,
当集合是数组,复选框的 label 和 value 相同;
当为 Map 集合,复选框的 label 是 Map 的值(value),复选框的 value 是 Map 的关键字(key)
radiobutton 标签
radiobutton 标签的语法格式如下:<form:radiobutton path="xxx" value="xxx"/>
多个 path 相同的 radiobutton 标签,它们是一个选项组,只允许单选。radiobuttons 标签
radiobuttons 标签渲染多个 radio,是一个选项组,相当于多个 path 相同的 radiobutton 标签。radiobuttons 标签的语法格式如下:
<form:radiobuttons items="xxx" path="xxx"/>
该标签的 itemLabel 和 itemValue 属性与 checkboxes 标签的 itemLabel 和 itemValue 属性完全一样,但只允许单选。select 标签
select 标签的选项可能来自其属性 items 指定的集合,或者来自一个嵌套的 option 标签或 options 标签。其语法格式如下:<form:select path="xxx" items="xxx"/>
或<form:select path="xxx" items="xxx">
<option value="xxx">xxx</option>
</form:select>
<form:select path="xxx">
<form:options items="xxx"/>
</form:select>
options 标签
options 标签生成一个 select 标签的选项列表此标签需结合select标签一起使用
errors 标签
errors 标签渲染一个或者多个 span 元素,每个 span 元素包含一个错误消息。<form:errors path="*"/>
或<form:errors path="xxx"/>
版权声明
本文仅代表作者观点,不代表本站立场。
本文系作者授权发表,未经许可,不得转载。