zoukankan      html  css  js  c++  java
  • SpringMVC5中,@ModelAttribute注解详解

    看这个注解的前提最好熟悉一下SpringMVC的model组件,该注解可以有五种使用方式:

     ①②③为 @ModelAttribute 跟@RequestMapping 分开修饰方法,被@ModelAttribute修饰的方法比 @RequestMapping修饰的方法先一步调用!!

    ④是 @ModelAttribute 跟 @RequestMapping 同时修饰方法,

    ⑤ 是@ModelAttribute 修饰方法的参数。

     例子说明

    ①:方法返回值为void,@ModelAttribute注解没有指定任何属性,这样的话需要将Model或者map传入方法中,如下:

        key为user1,value为User对象,可以用 ${requestScope.user1.userName} 取出

    @ModelAttribute
        //@ModelAttribute 没有指定值,且被修饰的方法返回值为void,则需要借助map或者model将数据模型放入request域
        public void getUser(Map<String, Object> map) {
            System.out.println("ModelAttribute1..");
            map.put("user1", new User("kelin","123aaa"));
        }

    ②:方法返回值为普通的pojo,@ModelAttribute注解没有指定任何属性,这样的话,request域中存入的对象名字默认为类型首字母小写,如下:

        key为user(类型首字母小写),value为User对象,可以用 ${requestScope.user.userName} 取出

    @ModelAttribute
        //@ModelAttribute 没有指定值,且被修饰方法有pojo类型的返回值,则request域中 key为返回值类型第一个字母小写的字符串,value为返回值
        public User getUser() {
            System.out.println("ModelAttribute2..");
            return new User("kelin","123aaa");
        }

    ③:方法返回值为普通的pojo,@ModelAttribute注解指定了value属性,这样的话,request域中就放入了一个对象,如下:

        key为user2,value为User对象,可以用 ${requestScope.user2.userName} 取出

    @ModelAttribute("user2")
        //@ModelAttribute 的值就是request域中的key,被该注解修饰的方法的返回值为对应的value
        public User getUser() {
            System.out.println("ModelAttribute3..");
            return new User("kelin","123aaa");
        }

    ④:两个注解同时修饰方法,看注释解释,有点不一样,返回的东西不是视图,而是request域中的值,返回的视图变成了 @RequestMapping中指定的value

    /*
         * @ModelAttribute 和 @RequestMapping 同时修饰一个方法
         * 
         * @ModelAttribute 中value为 request域中的key,被修饰的方法返回值为request域中的value
         * @RequestMapping 中value为 返回的视图名,此例中相当于定向到xxx/testModelAttribute4.jsp
         */
        
        @ModelAttribute(value="user")
        @RequestMapping(value="/testModelAttribute4..")
        public User testModelAttribute() {
            return new User("kelin","123aaa");
        }

    ⑤:@ModelAttribute 修饰方法参数(最常用),参数直接封装到对象中,比如常用的 pageNo,pageSize...

    /*
         * @ModelAttribute用于修饰入参,前台传过来的值自动赋予入参对于的属性
         */
        @RequestMapping("/testModelAttribute5")
        public String testModelAttribute(@ModelAttribute User user) {
            return "modelAttribute";
        }

    为尊重原创,特此声明此文为转载文档,原文作者:https://www.cnblogs.com/convict/p/9789619.html,如有任何疑问联系可删除。再次感谢作者!

  • 相关阅读:
    Effective C# 原则12:选择变量初始化而不是赋值语句
    Effective C# 原则20:明辨接口实现和虚函数重载的区别(译)
    Effective C# 原则18:实现标准的处理(Dispose)模式(译)
    Effective C# 原则19:选择定义和实现接口而不是继承(译)
    Is JoyFM goes over? Nope, I believe that JoyFM will stick together with us for a long time.
    Effective C# 原则15:使用using和try/finally来做资源清理(译)
    Effective C# 第二章:.Net资源管理(翻译)
    Effective C# 原则10: 明白GetHashCode()的缺陷(译)
    Effective C# 原则8:确保0对于值类型数据是有效的(翻译)
    Effective C# 原则23:避免返回内部类对象的引用(翻译)
  • 原文地址:https://www.cnblogs.com/yss818824/p/12365335.html
Copyright © 2011-2022 走看看