ImageVerifierCode 换一换
格式:DOCX , 页数:14 ,大小:20.13KB ,
资源ID:4043036      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/4043036.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(Spring MVC Spring的表单标签库.docx)为本站会员(b****5)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

Spring MVC Spring的表单标签库.docx

1、Spring MVC Spring的表单标签库Spring Framework开发参考:13.9.使用Spring的表单标签库从2.0版本开始,如果使用JSP和Spring Web MVC的话,Spring提供了一套支持数据绑定的标签集合,用于处理表单元素。 每个标签所支持的属性集合和与其对应的HTML标签相同,这就让这些标签看起来很熟悉,而且用起来很直观。 由这些标签库生成的HTML页面符合HTML 4.01/XHTML 1.0标准。 与其它表单/输入标签库不同,Spring的表单标签库与Spring Web MVC集成在一起, 使标签可以使用命令对象(command object)和你的控

2、制器处理的参考数据(reference data)。 就像下面这些例子展示的一样,表单标签让JSP更易于开发、阅读和维护。 让我们进入表单标签的领域,并通过一个例子研究每个标签如何使用。 当某些标签需要更进一步的解释时,我们已经把所生成的HTML片段也一起列了进来。 13.9.1.配置Spring的表单标签库包含在spring.jar中。 这个库的描述符(descriptor)叫做spring-form.tld。 要使用这个库中的标签,在JSP页面的开头加入下面声明:在上面的声明中,form就是为想要使用的这个库中的标签所确定的标签命名前缀。13.9.2.form标签这个标签会生成一个HTML

3、的“form”标签,同时为内部标签的绑定暴露了一个绑定路径(binding path)。 它把命令对象(command object)放在PageContext中,这样内部的标签就可以访问这个命令对象了。 这个库中的其他标签都是form标签的嵌套标签。 假设我们有一个叫做User的领域对象,它是一个JavaBean, 拥有诸如firstName和lastName这样的属性。 我们将把它当作返回form.jsp的表单控制器的表单支持对象(form backing object)。 下面是一个form.jsp可能的样子的例子: First Name: Last Name: 上面firstName和

4、lastName的值是从由页面控制器放置在PageContext中的命令对象中得到的。 请继续读下去来看几个关于如何使用form标签的内部标签的例子。 生成的HTML看起来就是一个标准的form: First Name: Last Name: 上面的JSP有一个预设前提,就是表单支持对象(form backing)的变量名是“command”。 如果你将这个表单支持对象用其他名称加以定义(这可算是一种最佳实践),你就可以将这个命名变量绑定到表单上,如下例所示: First Name: Last Name: 13.9.3.input标签这个标签生成一个“text”类型的HTML“input”标签

5、。 关于这个标签的示例,请见第13.9.2节 “form标签”。 13.9.4.checkbox标签这个标签生成一个“checkbox”类型的HTML“input”标签。让我们假设我们的User有比如新闻订阅和其他一组业余爱好这样的偏好。 下面就是一个Preferences类的例子: public class Preferences private boolean receiveNewsletter; private String interests; private String favouriteWord; public boolean isReceiveNewsletter() retu

6、rn receiveNewsletter; public void setReceiveNewsletter(boolean receiveNewsletter) this.receiveNewsletter = receiveNewsletter; public String getInterests() return interests; public void setInterests(String interests) this.interests = interests; public String getFavouriteWord() return favouriteWord; p

7、ublic void setFavouriteWord(String favouriteWord) this.favouriteWord = favouriteWord; form.jsp如下: Subscribe to newsletter?: Interests: Quidditch: Herbology: Defence Against the Dark Arts: Favourite Word: Magic: 有三种checkbox标签的使用方法满足你对checkbox的需求。 第一种用法:若绑定值是java.lang.Boolean类型,则值为true时,input(checkbox

8、)就标记为选中。其value属性对应于setValue(Object)值的属性的解析值。 第二种用法:若绑定值是array或java.util.Collection类型,则当设定的setValue(Object)值出现在绑定的Collection中时,input(checkbox)就标记为选中。 第三种用法:若绑定值为其他类型,则当设定的setValue(Object)与其绑定值相等时,input(checkbox)才标记为选中。注意,不管使用哪种方法,生成的HTML结构都是相同的。下面是包含一些checkbox的HTML片段: Interests: Quidditch: Herbology:

9、 Defence Against the Dark Arts: 也许没有注意到的是在每个checkbox背后还隐藏了其他字段(field)。 当一个HTML页面中的checkbox没有被选中时,它的值不会在表单提交时作为HTTP请求参数的一部分发送到服务器端, 因此我们需要给这个HTML的奇怪动作想出一个变通方案,来让Spring的表单数据绑定可以工作。 checkbox标签遵循了Spring现有的惯例,就是对于每个checkbox都包含了一个下划线(_),再跟上一个隐藏参数。 这样一来,就相当于告诉Spring“ 这个checkbox在表单中是可见的,并且希望表单数据将要被绑定到的对象能够反

10、映出任意的checkbox的状态”。 13.9.5.checkboxes标签这个标签生成多个“checkbox”类型的HTML“input”标签。这一节建立在上一节checkbox标签的例子之上。 有时倾向于并不在JSP页面中列出全部可能的业余爱好,而是想在运行时提供一个可用选项的清单,并把它传递给相应标签。 这就是checkboxes标签的目标。 传入一个Array、List,或者Map, 并把可用选项包含在“items”属性中。典型的情况是,这个绑定的属性是一个集合,这样它才能持有用户选择的多个值。 下面是使用了这个标签的JSP的一个例子: Interests: 这个例子假定了“inter

11、estList”是一个List,作为模型属性它包含了用于被选择的字符串的值。 而在使用一个Map的情况下,map条目的键被用作值,map条目的值被用作显示的文本标记。 也可以使用一个定制的对象,提供“itemValue”属性存放值,“itemLabel”属性存放文本标记。 13.9.6.radiobutton标签这个标签生成一个“radio”类型的HTML“input”标签。一个典型用法是把多个标签实例绑定到同一属性上,但它们有不同的值。 Sex: Male: Female: 13.9.7.radiobuttons标签这个标签生成多个“radio”类型的HTML“input”标签。正像上面提到

12、的checkboxes标签,你可能希望传入一个运行时的变量作为可用的选项。 这种用法下就需要使用radiobuttons标签。 传入一个Array、List,或者Map, 并把可用选项包含在“items”属性中。在使用Map的情况下,map条目的键被用作值, map条目的值被用作显示的文本标记。也可以使用一个定制的对象,提供“itemValue”属性存放值,“itemLabel”属性存放文本标记。 Sex: 13.9.8.password标签这个标签生成一个“password”类型的HTML“input”标签,并赋以绑定的值。 Password: 请注意默认情况下,口令的值不会被显示出来。 如

13、果一定要显示口令的值,就把“showPassword”属性的值置为true。 Password: 13.9.9.select标签这个标签生成一个HTML“select”元素。它支持被选中的选项的数据绑定, 也支持使用嵌套的option和options标签。 我们假设有一个User拥有多项专长。 Skills: 如果这个User的专长是草药学,那么“Skills”这一行的HTML源代码就如下所示: Skills: Potions Herbology Quidditch 13.9.10.option标签这个标签生成一个HTML的“option”。根据绑定的值,它会恰当的设置“selected”属性

14、。 House: 如果这个User的宿舍在Gryffindor(Gryffindor是哈利波特在Hogwarts的宿舍译者注), 那么“House”这一行的HTML源代码就如下所示: House: Gryffindor Hufflepuff Ravenclaw Slytherin 13.9.11.options标签这个标签生成一个HTML的“option”标签的列表。根据绑定的值,它会恰当的设置“selected”属性。 Country: 如果这个User生活在英国,那么“Country”这一行的HTML源代码就如下所示: Country: -Please Select Austria Uni

15、ted Kingdom United States 上面的例子展示了结合使用option标签和options标签产生相同的标准HTML, 也让你在JSP中显式的指定一个值只用于显示目的(在它所处的位置),例如例子中的默认字符串:“-Please Select”。13.9.12.textarea标签这个标签生成一个HTML的“textarea”。 Notes: 13.9.13.hidden标签这个标签使用绑定的值生成类型为“hidden”的HTML“input”标签。 在生成的HTML代码中,input标签的值和表单支持对象相应属性的值保持一致。 如果要提交一个未绑定的值,就只能使用类型为“hi

16、dden”的HTML input标签了。 如果我们选择以隐藏形式提交“house”的值,HTML代码将如下所示:13.9.14.errors标签这个标签通过一个HTML“span”标签展现字段的错误。它提供了访问由你的控制器或者与你的控制器关联的任何验证器产生的错误的途径。假设我们想要在表单提交时显示所有与firstName和lastName字段有关的错误。 我们为User类的实例编写了名为UserValidator的验证器。 public class UserValidator implements Validator public boolean supports(Class candid

17、ate) return User.class.isAssignableFrom(candidate); public void validate(Object obj, Errors errors) ValidationUtils.rejectIfEmptyOrWhitespace(errors, firstName, required, Field is required.); ValidationUtils.rejectIfEmptyOrWhitespace(errors, lastName, required, Field is required.); form.jsp将如下所示: First Name: Last Name: input type=submit val

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1