1、绑定请求参数到指定对象
此方法会先从model去获取key为”user”的对象,如果获取不到会通过反射实例化一个User对象,再从request里面拿值set到这个对象,然后把这个User对象添加到model(其中key为”user”).使用了@ModelAttribute已经修改这个key,不一定是”user”,当key为”userTest”时,用与不用@ModelAttribute没有区别.
@RequestMapping("/test")
public String test(@ModelAttribute("user") UserTest user)
只是此处多了一个注解@ModelAttribute(“user”),它的作用是将该绑定的命令对象以“user”为名称添加到模型对象中供视图页面展示使用。我们此时可以在视图页面使用${user.name}来获取绑定的命令对象的属性。
请求参数为:URL?name=”yd”&pwd=”123456”&age=25
则结果为:name:”yd” age:25 pwd:123456
@RequestMapping("/test")
public String test(@ModelAttribute("user") UserTest user){
user.setAge(34);
user.setName("uu");
return "views/dataBind/detail";
}
则结果为:name:”uu” age:34 pwd:123456
URI 模板变量也能自动绑定到命令对象中
@RequestMapping("/test2/{name}/{pwd}")
public String test2(@ModelAttribute("user") UserTest user)
当URI模板变量和请求参数同名时,URI模板变量具有高优先权。
请求参数为:/test2/{name}/{pwd}
当请求参数为:/test2/yd/123?name=”yd4”&age=12
则结果为:name:”yd4” age:12 pwd:123
2、在方法上使用@ModelAttribute
暴露表单引用对象为模型数据:放在处理器的一般方法(非功能处理方法)上时,是为表单准备要展示的表单引用对象,如注册时需要选择的所在城市等,而且在执行功能处理方法(@RequestMapping 注解的方法)之前,自动添加到模型对象中,用于视图页面展示时使用;
/**
* 设置这个注解之后可以直接在前端页面使用list这个对象(List)集合
* @return
*/
@ModelAttribute("listA")
public List<String> list(){
List<String> list = new ArrayList<>();
list.add("basketball");
list.add("football");
list.add("tennis");
return list;
}
//可以直接使用listA集合的值
<div>
<p>${fn:length(listA)}</p>
<c:forEach items="${listA}" var="list">
<div>
<c:out value="${list}" />
</div>
</c:forEach>
</div>
@ModelAttribute("user1")
public UserTest addUser(UserTest user) {
return new UserTest("ydM","666",123);
}
<p>
姓名:${userTest.name}<br />年龄:${userTest.age}<br /> 密码:${userTest.pwd}<br />
姓名:${user1.name}<br />年龄:${user1.age}<br /> 密码:${user1.pwd}<br />
</p>
执行结果:
姓名:"yd4"
年龄:12
密码:"12345"
姓名:ydM
年龄:123
密码:666
假设此方法是写在UserController内,那么执行UserController内带有@RequestMapping的方法之前,都会先执行此addUser方法和list方法.并且执行addUser过程中会添加两个对象到model,先将key为”userTest“的对象(由addUser方法的UserTest user引起的),再添加key为”user1“的对象(由注解@ModelAttribute(“user1”)引起的,即return的值).
执行list方法过程中会添加key为list A的list集合;
3.再来看看在方法和方法参数上结合使用@ModelAttribute
即上面两步的两个方法都添加UserController,如下:
@ModelAttribute("user1")//(1)
public UserTest addUser(UserTest user) {
return new UserTest("ydM","666",123);
}
@RequestMapping("/save")//(2)
public String save(@ModelAttribute("user1") UserTest user) {
System.out.println(user.getName());
return "views/dataBind/detail";
}
假设要执行保存用户操作,根据一分析可知,先执行完会产生两个User类型的对象(一个key是”userTest”,另一个key是”user1”)添加到model,再执行save方法,此时会先从model去找key为”user1”的对象,能找到再从request取值set到这个UserTest对象.最后返回到jsp页面,model里也只有两个UserTest类型对象.
再来个小小假设,将上面(1)@ModelAttribute(“user1”)的user1改为userTest,(2)去掉“user1”.虽然执行了addUser方法,那么执行到save方法内,user对象的字段值还是来源于请求,最后返回到jsp页面,model里也只有一个UserTest类型对象.
4、另类
@ModelAttribute
@RequestMapping("/save2")
public String save2(@ModelAttribute UserTest user) {
user.setName("U love me");
System.out.println(user.getName());
return "views/dataBind/detail";
}
此种情况,会添加一个key为”userTest”的User对象到model,还会添加一个key为”string”,value为”views/dataBind/detail”的对象到model,而视图名称则变为了”save”而不是”views/dataBind/detail”.相信一般开发者都不会这样用.
运行结果:
HTTP Status 404 - /WEB-INF/requestModel/save2.jsp