博客
关于我
springMVC前端传值的几种方法(基本数据类型、包装类型、自定义类型、集合)
阅读量:627 次
发布时间:2019-03-11

本文共 3927 字,大约阅读时间需要 13 分钟。

1. 基本数据类型(以int为例,其他类似):

Controller代码:

@RequestMapping("saysth.do")public void test(int count) {}

表单代码:

......

表单中input的name值和Controller的参数变量名保持一致,就能完成数据绑定,如果不一致可以使用@RequestParam注解。需要注意的是,如果Controller方法参数中定义的是基本数据类型,但是从页面提交过来的数据为null或者”"的话,会出现数据转换的异常。

也就是必须保证表单传递过来的数据不能为null或”",所以,在开发过程中,对可能为空的数据,最好将参数数据类型定义成包装类型,具体参见下面的例子。

2. 包装类型(以Integer为例,其他类似):

Controller代码:

@RequestMapping("saysth.do")public void test(Integer count) {}

表单代码:

......

和基本数据类型基本一样,不同之处在于,表单传递过来的数据可以为null或”",以上面代码为例,如果表单中num为”"或者表单中无num这个input,那么,Controller方法参数中的num值则为null。

3. 自定义对象类型:

Model代码:

public class User { private String firstName; private String lastName;   省略set,get 方法}

Controller代码:

@RequestMapping("saysth.do")public void test(User user) {}

表单代码:

......

4. 自定义复合对象类型:

Model代码:

public class ContactInfo { private String tel; private String address; 省略set ,get  } public class User { private String firstName; private String lastName; private ContactInfo contactInfo;   省略set ,get  }

Controller代码:

@RequestMapping("saysth.do")public void test(User user) { System.out.println(user.getFirstName()); System.out.println(user.getLastName()); System.out.println(user.getContactInfo().getTel()); System.out.println(user.getContactInfo().getAddress());}

表单代码:

User对象中有ContactInfo属性,Controller中的代码和第3点说的一致,但是,在表单代码中,需要使用“属性名(对象类型的属性).属性名”来命名input的name。

5. List绑定:

List需要绑定在对象上,而不能直接写在Controller方法的参数中。

Model代码:

public class User { private String firstName; private String lastName;省略set ,get  } public class UserListForm { private List
users; public List
getUsers() { return users; } public void setUsers(List
users) { this.users = users; } }

Controller代码:

@RequestMapping("saysth.do")public void test(UserListForm userForm) { for (User user : userForm.getUsers()) {  System.out.println(user.getFirstName() + " - " + user.getLastName()); }}

表单代码:

其实,这和第4点User对象中的contantInfo数据的绑定有点类似,但是这里的UserListForm对象里面的属性被定义成List,而不是普通自定义对象。

所以,在表单中需要指定List的下标。值得一提的是,spring会创建一个以最大下标值为size的List对象,所以,如果表单中有动态添加行、删除行的情况,就需要特别注意,譬如一个表格,用户在使用过程中经过多次删除行、增加行的操作之后,下标值就会与实际大小不一致,

这时候,List中的对象,只有在表单中对应有下标的那些才会有值,否则会为null,看个例子:

表单代码:

这个时候,Controller中的userForm.getUsers()获取到List的size为21,而且这21个User对象都不会为null,但是,第2到第19的User对象中的firstName和lastName都为null。打印结果:

aaa - bbb
ccc - ddd
null - null
null - null
null - null
eee - fff

6. Set绑定:

Set和List类似,也需要绑定在对象上,而不能直接写在Controller方法的参数中。但是,绑定Set数据时,必须先在Set对象中add相应的数量的模型对象。
Model代码:

public class User { private String firstName; private String lastName;省略set ,get  } public class UserSetForm { private Set
users = new HashSet
(); public UserSetForm() { users.add(new User()); users.add(new User()); users.add(new User()); } public Set
getUsers() { return users; } public void setUsers(Set
users) { this.users = users; } }

Controller代码:

@RequestMapping("saysth.do")public void test(UserSetForm userForm) { for (User user : userForm.getUsers()) {  System.out.println(user.getFirstName() + " - " + user.getLastName()); }}

表单代码:

基本和List绑定类似。

需要特别提醒的是,如果最大下标值大于Set的size,则会抛出org.springframework.beans.InvalidPropertyException异常。所以,在使用时有些不便。

7. Map绑定:

Model代码:

public class User { private String firstName; private String lastName;省略set ,get  } public class UserMapForm { private Map
users; public Map
getUsers() { return users; } public void setUsers(Map
users) { this.users = users; } }

Controller代码:

@RequestMapping("saysth.do")public void test(UserMapForm userForm) { for (Map.Entry
entry : userForm.getUsers().entrySet()) { System.out.println(entry.getKey() + ": " + entry.getValue().getFirstName() + " - " + entry.getValue().getLastName()); }}

表单代码:

初上手ssm集成项目,转载作参考。

原文地址:

你可能感兴趣的文章
Navicat可视化界面导入SQL文件生成数据库表
查看>>
Navicat向sqlserver中插入数据时提示:当 IDENTITY_INSERT 设置为 OFF 时,不能向表中的标识列插入显式值
查看>>
Navicat因导入的sql文件中时间数据类型有参数而报错的原因(例:datetime(3))
查看>>
Navicat如何连接MySQL
查看>>
navicat导入.sql文件出错2006- MySQLserver has gone away
查看>>
Navicat导入海量Excel数据到数据库(简易介绍)
查看>>
Navicat工具Oracle数据库复制 or 备用、恢复功能(评论都在谈论需要教)
查看>>
Navicat工具中建立数据库索引
查看>>
navicat工具查看MySQL数据库_表占用容量_占用空间是多少MB---Linux工作笔记048
查看>>
navicat怎么导出和导入数据表
查看>>
Navicat怎样同步两个数据库中的表
查看>>
Navicat怎样筛选数据
查看>>
Navicat报错connection is being used
查看>>
Navicat报错:1045-Access denied for user root@localhost(using passwordYES)
查看>>
Navicat控制mysql用户权限
查看>>
navicat操作mysql中某一张表后, 读表时一直显示正在载入,卡死不动,无法操作
查看>>
Navicat连接mysql 2003 - Can't connect to MySQL server on ' '(10038)
查看>>
Navicat连接mysql数据库中出现的所有问题解决方案(全)
查看>>
Navicat连接Oracle出现Oracle library is not loaded的解决方法
查看>>
Navicat连接Oracle数据库以及Oracle library is not loaded的解决方法
查看>>