@ModelAttribute注解的使用

在SpringMVC的Controller中使用@ModelAttribute時(shí),其位置包括下面三種:

  • 應(yīng)用在方法上
  • 應(yīng)用在方法的參數(shù)上
  • 應(yīng)用在方法上,并且方法也使用了@RequestMapping

應(yīng)用在方法上

首先說明一下,被@ModelAttribute注解的方法會(huì)在Controller每個(gè)方法執(zhí)行之前都執(zhí)行,因此對(duì)于一個(gè)Controller中包含多個(gè)URL的時(shí)候,要謹(jǐn)慎使用。

1)使用@ModelAttribute注解無返回值的方法

@Controller
@RequestMapping(value = "/modelattribute")
public class ModelAttributeController {

    @ModelAttribute
    public void myModel(@RequestParam(required = false) String abc, Model model) {
        model.addAttribute("attributeName", abc);
    }

    @RequestMapping(value = "/method")
    public String method() {
        return "method";
    }
}

這個(gè)例子,在請(qǐng)求/modelattribute/method?abc=aaa后,會(huì)先執(zhí)行myModel方法,然后接著執(zhí)行method方法,參數(shù)abc的值被放到Model中后,接著被帶到method方法中。

當(dāng)返回視圖/modelattribute/method時(shí),Model會(huì)被帶到頁面上,當(dāng)然你在使用@RequestParam的時(shí)候可以使用required來指定參數(shù)是否是必須的。

如果把myModelmethod合二為一,代碼如下,這也是我們最常用的方法:

@RequestMapping(value = "/method")
public String method(@RequestParam(required = false) String abc, Model model) {
    model.addAttribute("attributeName", abc);
    return "method";
}

2)使用@ModelAttribute注解帶有返回值的方法

@ModelAttribute
public String myModel(@RequestParam(required = false) String abc) {
    return abc;
}

@ModelAttribute
public Student myModel(@RequestParam(required = false) String abc) {
    Student student = new Student(abc);
    return student;
}

@ModelAttribute
public int myModel(@RequestParam(required = false) int number) {
    return number;
}

對(duì)于這種情況,返回值對(duì)象會(huì)被默認(rèn)放到隱含的Model中,在Model中的key返回值首字母小寫value為返回的值。

上面3種情況等同于:

model.addAttribute("string", abc);
model.addAttribute("int", number);
model.addAttribute("student", student);

在jsp頁面使用${int}表達(dá)式時(shí)會(huì)報(bào)錯(cuò):javax.el.ELException: Failed to parse the expression [${int}]。
解決辦法:
在tomcat的配置文件conf/catalina.properties添加配置org.apache.el.parser.SKIP_IDENTIFIER_CHECK=true

如果只能這樣,未免太局限了,我們很難接受keystringint、float等等這樣的。

想自定義其實(shí)很簡(jiǎn)單,只需要給@ModelAttribute添加value屬性即可,如下:

@ModelAttribute(value = "num")
public int myModel(@RequestParam(required = false) int number) {
    return number;
}

這樣就相當(dāng)于model.addAttribute("num", number);

使用@ModelAttribute注解的參數(shù)

@Controller
@RequestMapping(value = "/modelattribute")
public class ModelAttributeParamController {

    @ModelAttribute(value = "attributeName")
    public String myModel(@RequestParam(required = false) String abc) {
        return abc;
    }

    @ModelAttribute
    public void myModel3(Model model) {
        model.addAttribute("name", "zong");
        model.addAttribute("age", 20);
    }

    @RequestMapping(value = "/param")
    public String param(@ModelAttribute("attributeName") String str,
                       @ModelAttribute("name") String str2,
                       @ModelAttribute("age") int str3) {
        return "param";
    }
}

從代碼中可以看出,使用@ModelAttribute注解的參數(shù),意思是從前面的Model中提取對(duì)應(yīng)名稱的屬性。

這里提及一下@SessionAttributes的使用:

  • 如果在類上面使用了@SessionAttributes("attributeName")注解,而本類中恰巧存在attributeName,則會(huì)將attributeName放入到session作用域。
  • 如果在類上面使用了@SessionAttributes("attributeName")注解,SpringMVC會(huì)在執(zhí)行方法之前,自動(dòng)從session中讀取keyattributeName的值,并注入到Model中。所以我們?cè)诜椒ǖ膮?shù)中使用ModelAttribute("attributeName")就會(huì)正常的從Model讀取這個(gè)值,也就相當(dāng)于獲取了session中的值。
  • 使用了@SessionAttributes之后,Spring無法知道什么時(shí)候要清掉@SessionAttributes存進(jìn)去的數(shù)據(jù),如果要明確告知,也就是在方法中傳入SessionStatus對(duì)象參數(shù),并調(diào)用status.setComplete就可以了。

應(yīng)用在方法上,并且方法上也使用了@RequestMapping

@Controller
@RequestMapping(value = "/modelattribute")
public class ModelAttributeController {

    @RequestMapping(value = "/test")
    @ModelAttribute("name")
    public String test(@RequestParam(required = false) String name) {
        return name;
    }
}

這種情況下,返回值String(或者其他對(duì)象)就不再是視圖了,而是放入到Model中的值,此時(shí)對(duì)應(yīng)的頁面就是@RequestMapping的值test
如果類上有@RequestMapping,則視圖路徑還要加上類的@RequestMapping的值,本例中視圖路徑為modelattribute/test.jsp。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

友情鏈接更多精彩內(nèi)容