Spring MVC Spring的表单标签库.docx
- 文档编号:4043036
- 上传时间:2022-11-27
- 格式:DOCX
- 页数:14
- 大小:20.13KB
Spring MVC Spring的表单标签库.docx
《Spring MVC Spring的表单标签库.docx》由会员分享,可在线阅读,更多相关《Spring MVC Spring的表单标签库.docx(14页珍藏版)》请在冰豆网上搜索。
SpringMVCSpring的表单标签库
SpringFramework开发参考:
13.9. 使用Spring的表单标签库
从2.0版本开始,如果使用JSP和SpringWebMVC的话,Spring提供了一套支持数据绑定的标签集合,用于处理表单元素。
每个标签所支持的属性集合和与其对应的HTML标签相同,这就让这些标签看起来很熟悉,而且用起来很直观。
由这些标签库生成的HTML页面符合HTML4.01/XHTML1.0标准。
与其它表单/输入标签库不同,Spring的表单标签库与SpringWebMVC集成在一起,使标签可以使用命令对象(commandobject)和你的控制器处理的参考数据(referencedata)。
就像下面这些例子展示的一样,表单标签让JSP更易于开发、阅读和维护。
让我们进入表单标签的领域,并通过一个例子研究每个标签如何使用。
当某些标签需要更进一步的解释时,我们已经把所生成的HTML片段也一起列了进来。
13.9.1. 配置
Spring的表单标签库包含在spring.jar中。
这个库的描述符(descriptor)叫做spring-form.tld。
要使用这个库中的标签,在JSP页面的开头加入下面声明:
<%@taglibprefix="form"uri="http:
//www.springframework.org/tags/form"%>
在上面的声明中,form就是为想要使用的这个库中的标签所确定的标签命名前缀。
13.9.2. form标签
这个标签会生成一个HTML的“form”标签,同时为内部标签的绑定暴露了一个绑定路径(bindingpath)。
它把命令对象(commandobject)放在PageContext中,这样内部的标签就可以访问这个命令对象了。
这个库中的其他标签都是form标签的嵌套标签。
假设我们有一个叫做User的领域对象,它是一个JavaBean,拥有诸如firstName和lastName这样的属性。
我们将把它当作返回form.jsp的表单控制器的表单支持对象(formbackingobject)。
下面是一个form.jsp可能的样子的例子:
form> inputpath="firstName"/> inputpath="lastName"/>FirstName: LastName:
form>
上面firstName和lastName的值是从由页面控制器放置在PageContext中的命令对象中得到的。
请继续读下去来看几个关于如何使用form标签的内部标签的例子。
生成的HTML看起来就是一个标准的form:
FirstName: | |
LastName: | |
上面的JSP有一个预设前提,就是表单支持对象(formbacking)的变量名是“command”。
如果你将这个表单支持对象用其他名称加以定义(这可算是一种最佳实践),你就可以将这个命名变量绑定到表单上,如下例所示:
formcommandName="user"> inputpath="firstName"/> inputpath="lastName"/>FirstName: LastName:
form>
13.9.3. input标签
这个标签生成一个“text”类型的HTML“input”标签。
关于这个标签的示例,请见第 13.9.2 节“form标签”。
13.9.4. checkbox标签
这个标签生成一个“checkbox”类型的HTML“input”标签。
让我们假设我们的User有比如新闻订阅和其他一组业余爱好这样的偏好。
下面就是一个Preferences类的例子:
publicclassPreferences{
privatebooleanreceiveNewsletter;
privateString[]interests;
privateStringfavouriteWord;
publicbooleanisReceiveNewsletter(){
returnreceiveNewsletter;
}
publicvoidsetReceiveNewsletter(booleanreceiveNewsletter){
this.receiveNewsletter=receiveNewsletter;
}
publicString[]getInterests(){
returninterests;
}
publicvoidsetInterests(String[]interests){
this.interests=interests;
}
publicStringgetFavouriteWord(){
returnfavouriteWord;
}
publicvoidsetFavouriteWord(StringfavouriteWord){
this.favouriteWord=favouriteWord;
}
}
form.jsp如下:
form> : <%--Approach1: Propertyisoftypejava.lang.Boolean--%> checkboxpath="preferences.receiveNewsletter"/> <%--Approach2: Propertyisofanarrayoroftypejava.util.Collection--%> Quidditch: checkboxpath="preferences.interests"value="Quidditch"/> Herbology: checkboxpath="preferences.interests"value="Herbology"/> DefenceAgainsttheDarkArts: checkboxpath="preferences.interests" value="DefenceAgainsttheDarkArts"/> <%--Approach3: Propertyisoftypejava.lang.Object--%> Magic: checkboxpath="preferences.favouriteWord"value="Magic"/>Subscribetonewsletter? Interests: FavouriteWord:
form>
有三种checkbox标签的使用方法满足你对checkbox的需求。
∙第一种用法:
若绑定值是java.lang.Boolean类型,则值为true时,input(checkbox)就标记为选中。
其value属性对应于setValue(Object)值的属性的解析值。
∙第二种用法:
若绑定值是array或java.util.Collection类型,则当设定的setValue(Object)值出现在绑定的Collection中时,input(checkbox)就标记为选中。
∙第三种用法:
若绑定值为其他类型,则当设定的setValue(Object)与其绑定值相等时,input(checkbox)才标记为选中。
注意,不管使用哪种方法,生成的HTML结构都是相同的。
下面是包含一些checkbox的HTML片段:
Quidditch:
Herbology:
DefenceAgainsttheDarkArts:
value="DefenceAgainsttheDarkArts"/>
也许没有注意到的是在每个checkbox背后还隐藏了其他字段(field)。
当一个HTML页面中的checkbox没有被选中时,它的值不会在表单提交时作为HTTP请求参数的一部分发送到服务器端,因此我们需要给这个HTML的奇怪动作想出一个变通方案,来让Spring的表单数据绑定可以工作。
checkbox标签遵循了Spring现有的惯例,就是对于每个checkbox都包含了一个下划线("_"),再跟上一个隐藏参数。
这样一来,就相当于告诉Spring“这个checkbox在表单中是可见的,并且希望表单数据将要被绑定到的对象能够反映出任意的checkbox的状态”。
13.9.5. checkboxes标签
这个标签生成多个“checkbox”类型的HTML“input”标签。
这一节建立在上一节checkbox标签的例子之上。
有时倾向于并不在JSP页面中列出全部可能的业余爱好,而是想在运行时提供一个可用选项的清单,并把它传递给相应标签。
这就是checkboxes标签的目标。
传入一个Array、List,或者Map,并把可用选项包含在“items”属性中。
典型的情况是,这个绑定的属性是一个集合,这样它才能持有用户选择的多个值。
下面是使用了这个标签的JSP的一个例子:
form> <%--Propertyisofanarrayoroftypejava.util.Collection--%> checkboxespath="preferences.interests"items="${interestList}"/>Interests:
form>
这个例子假定了“interestList”是一个List,作为模型属性它包含了用于被选择的字符串的值。
而在使用一个Map的情况下,map条目的键被用作值,map条目的值被用作显示的文本标记。
也可以使用一个定制的对象,提供“itemValue”属性存放值,“itemLabel”属性存放文本标记。
13.9.6. radiobutton标签
这个标签生成一个“radio”类型的HTML“input”标签。
一个典型用法是把多个标签实例绑定到同一属性上,但它们有不同的值。
radiobuttonpath="sex"value="M"/> Female: radiobuttonpath="sex"value="F"/>
13.9.7. radiobuttons标签
这个标签生成多个“radio”类型的HTML“input”标签。
正像上面提到的checkboxes标签,你可能希望传入一个运行时的变量作为可用的选项。
这种用法下就需要使用radiobuttons标签。
传入一个Array、List,或者Map,并把可用选项包含在“items”属性中。
在使用Map的情况下,map条目的键被用作值,map条目的值被用作显示的文本标记。
也可以使用一个定制的对象,提供“itemValue”属性存放值,“itemLabel”属性存放文本标记。
radiobuttonspath="sex"items="${sexOptions}"/>
13.9.8. password标签
这个标签生成一个“password”类型的HTML“input”标签,并赋以绑定的值。
passwordpath="password"/>
请注意默认情况下,口令的值不会被显示出来。
如果一定要显示口令的值,就把“showPassword”属性的值置为true。
passwordpath="password"value="^76525bvHGq"showPassword="true"/>
13.9.9. select标签
这个标签生成一个HTML“select”元素。
它支持被选中的选项的数据绑定,也支持使用嵌套的option和options标签。
我们假设有一个User拥有多项专长。
selectpath="skills"items="${skills}"/>
如果这个User的专长是草药学,那么“Skills”这一行的HTML源代码就如下所示:
13.9.10. option标签
这个标签生成一个HTML的“option”。
根据绑定的值,它会恰当的设置“selected”属性。
selectpath="house"> optionvalue="Gryffindor"/> optionvalue="Hufflepuff"/> optionvalue="Ravenclaw"/> optionvalue="Slytherin"/> select>
如果这个User的宿舍在Gryffindor(Gryffindor是哈利·波特在Hogwarts的宿舍——译者注),那么“House”这一行的HTML源代码就如下所示:
13.9.11. options标签
这个标签生成一个HTML的“option”标签的列表。
根据绑定的值,它会恰当的设置“selected”属性。
selectpath="country"> optionvalue="-"label="--PleaseSelect"/> optionsitems="${countryList}"itemValue="code"itemLabel="name"/> select>
如果这个User生活在英国,那么“Country”这一行的HTML源代码就如下所示:
上面的例子展示了结合使用option标签和options标签产生相同的标准HTML,也让你在JSP中显式的指定一个值只用于显示目的(在它所处的位置),例如例子中的默认字符串:
“--PleaseSelect”。
13.9.12. textarea标签
这个标签生成一个HTML的“textarea”。
textareapath="notes"rows="3"cols="20"/>
errorspath="notes"/>
13.9.13. hidden标签
这个标签使用绑定的值生成类型为“hidden”的HTML“input”标签。
在生成的HTML代码中,input标签的值和表单支持对象相应属性的值保持一致。
如果要提交一个未绑定的值,就只能使用类型为“hidden”的HTMLinput标签了。
hiddenpath="house"/> 如果我们选择以隐藏形式提交“house”的值,HTML代码将如下所示: 13.9.14. errors标签 这个标签通过一个HTML“span”标签展现字段的错误。 它提供了访问由你的控制器或者与你的控制器关联的任何验证器产生的错误的途径。 假设我们想要在表单提交时显示所有与firstName和lastName字段有关的错误。 我们为User类的实例编写了名为UserValidator的验证器。 publicclassUserValidatorimplementsValidator{ publicbooleansupports(Classcandidate){ returnUser.class.isAssignableFrom(candidate); } publicvoidvalidate(Objectobj,Errorserrors){ ValidationUtils.rejectIfEmptyOrWhitespace(errors,"firstName","required","Fieldisrequired."); ValidationUtils.rejectIfEmptyOrWhitespace(errors,"lastName","required","Fieldisrequired."); } } form.jsp将如下所示: form> inputpath="firstName"/> <%--ShowerrorsforfirstNamefield--%> errorspath="firstName"/> inputpath="lastName"/> <%--ShowerrorsforlastNamefield--%> errorspath="lastName"/> 如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。 copyright@ 2008-2022 冰点文档网站版权所有 经营许可证编号:鄂ICP备2022015515号-1FirstName: LastName: