@ModelAttribute注解的作用
来源:互联网 发布:三维人像综合数据门 编辑:程序博客网 时间:2024/06/07 10:43
1.@ModelAttribute注释void返回值的方法
在这个代码中,访问控制器方法helloWorld时,会首先调用populateModel方法,将页面参数abc(/helloWorld.ht?abc=text)放到model的attributeName属性中,在视图中可以直接访问。
jsp页面页面如下:
2.@ModelAttribute注释返回具体类的方法
当用户请求 http://localhost:8080/test/helloWorld2.html时,首先访问populateModel方法,返回User对象,model属性的名称没有指定,它由返回类型隐含表示,如这个方法返回User类型,那么这个model属性的名称是user。
这个例子中model属性名称有返回对象类型隐含表示,model属性对象就是方法的返回值。它无须要特定的参数。
jsp 中如下访问:
也可以指定属性名称
jsp中如下访问:
对象合并:
对象合并指定对象名称:
这样在jsp中可以使用如下方式访问
3.通过此特性控制权限.
我们可以在基类方法中控制写此注解,需要控制权限的控制器,继承控制器就可以了。
需要控制权限的类继承BaseController
这样就可以控制权限了,当然控制权限的方法有很多,比如通过过滤器等。这里只是提供一种思路。
总结:
@ModelAttribute具有如下三个作用:
①绑定请求参数到命令对象:放在功能处理方法的入参上时,用于将多个请求参数绑定到一个命令对象,从而简化绑定流程,而且自动暴露为模型数据用于视图页面展示时使用。其实@ModelAttribute此处对于供视图页面展示来说与model.addAttribute("attributeName", abc);功能类似。
此处多了一个注解@ModelAttribute("user"),它的作用是将该绑定的命令对象以“user”为名称添加到模型对象中供视图页面展示使用。我们此时可以在视图页面使用${user.username}来获取绑定的命令对象的属性。
②暴露@RequestMapping 方法返回值为模型数据:放在功能处理方法的返回值上时,是暴露功能处理方法的返回值为模型数据,用于视图页面展示时使用。
大家可以看到返回值类型是命令对象类型,而且通过@ModelAttribute("user2")注解,此时会暴露返回值到模型数据( 名字为user2 ) 中供视图展示使用
@ModelAttribute 注解的返回值会覆盖@RequestMapping 注解方法中的@ModelAttribute 注解的同名命令对象
③暴露表单引用对象为模型数据:放在处理器的一般方法(非功能处理方法)上时,是为表单准备要展示的表单引用对象,如注册时需要选择的所在城市等,而且在执行功能处理方法(@RequestMapping 注解的方法)之前,自动添加到模型对象中,用于视图页面展示时使用
- @ModelAttribute注解的作用
- @ModelAttribute注解的作用
- @ModelAttribute注解的作用
- SpringMVC中@ModelAttribute注解的作用
- springmvc的ModelAttribute注解
- @ModelAttribute注解的用法
- springmvc的ModelAttribute注解
- @ModelAttribute注解的使用
- springmvc的ModelAttribute注解
- springmvc的ModelAttribute注解
- springmvc的ModelAttribute注解
- Springmvc的@ModelAttribute注解
- springmvc的ModelAttribute注解
- springmvc的ModelAttribute注解
- @ModelAttribute注解的应用
- springmvc的ModelAttribute注解
- SpringMVC的ModelAttribute注解
- spring的@ModelAttribute作用
- chrome开发小技巧
- log4qt使用示例
- 1.找出数组元素item在给定数组arr中的位置
- Qt出现乱码解决办法
- PHPStrom 支持GO语言
- @ModelAttribute注解的作用
- 应用性能管理工具PinPoint介绍
- nginx 502/页面图片加载不出的原因
- mysql的正则表达式
- 源码阅读技巧篇
- IE F12 debug using
- c语言操作符
- c++primer5 题3.24
- Invalid bound statement (not found)