java中@ModelAttribute注解的作用
問(wèn)題描述:當(dāng)我們使用表單傳值得時(shí)候,如果定義了,name,address,age。等屬性,那么通過(guò)表單傳過(guò)去的值就只有這3個(gè)屬性,但是我們需要的name,pass,address,age等四個(gè)屬性。那么在提交表單并賦值的時(shí)候就會(huì)出現(xiàn),未得到的值為null的情況。如下圖:
獲取的pass為null
那么我們需要用@ModelAttribute注解來(lái)解決他:
實(shí)現(xiàn)代碼如下:
@ModelAttribute public void getUsers(@RequestParam(value="name",required=false) String name,Map<String, Object> map){ if(name!=null){ System.out.println("調(diào)用ModelAttribute"); //模擬從數(shù)據(jù)庫(kù)中獲取的對(duì)象。 User users = new User("cjh","123","123@qq.com","China"); System.out.println("從數(shù)據(jù)庫(kù)中獲取一個(gè)對(duì)象"+users); map.put("user",users); } } @RequestMapping("/getInfo") public String getServletAPI(User user){ String viewName = "hello"; System.out.println("修改:"+user); return viewName; }
@ModelAttribute注解的方法,在這個(gè)控制器中不管其他任何一個(gè)方法被調(diào)用,都會(huì)執(zhí)行。
以上代碼的運(yùn)行流程為:
1.首先執(zhí)行@ModelAttribute注解修飾的方法,從數(shù)據(jù)庫(kù)中查找出對(duì)應(yīng)要修改的對(duì)象,把值放在map鍵值對(duì)中,key應(yīng)該和處理請(qǐng)求的方法傳入的參數(shù)名一樣,如:此處定義的傳入?yún)?shù)名為user,那么map.put(“user”,值(從數(shù)據(jù)庫(kù)中查詢(xún)的對(duì)象))。這個(gè)Map需要定義在方法入?yún)⒌牡胤剑ùa如上)。
2.Spring MVC會(huì)從Map中找出user對(duì)象,并把表單請(qǐng)求參數(shù)賦值給該user對(duì)象,只有表單定義了的屬性才會(huì)被替換,沒(méi)定義的為null,不改變。所以要求@ModelAttribute修飾的方法中定義的key的名稱(chēng)要和控制器方法(@RequestMapping()修飾的方法)中入?yún)⒌拿Q(chēng)要一致。否則沒(méi)效果。
3.Spring MVC 把上述對(duì)象傳入目標(biāo)方法的參數(shù)。
注意:在@ModelAttribute 修飾的方法中,放入到map時(shí)的鍵要和目標(biāo)方法入?yún)㈩?lèi)型的參數(shù)名一致。
最終效果:
以上就是本文的全部?jī)?nèi)容,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,同時(shí)也希望多多支持腳本之家!
相關(guān)文章
詳解SpringBoot靜態(tài)方法獲取bean的三種方式
本文主要介紹了詳解SpringBoot靜態(tài)方法獲取bean的三種方式,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-10-10淺談java對(duì)象轉(zhuǎn)json,數(shù)字精確出現(xiàn)丟失問(wèn)題
下面小編就為大家?guī)?lái)一篇淺談java對(duì)象轉(zhuǎn)json, 數(shù)字精確出現(xiàn)丟失問(wèn)題。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-03-03詳細(xì)說(shuō)明關(guān)于Java的數(shù)據(jù)庫(kù)連接(JDBC)
這篇文章主要介紹了詳細(xì)說(shuō)明關(guān)于Java的數(shù)據(jù)庫(kù)連接JDBC,JDBC是用Java語(yǔ)言向數(shù)據(jù)庫(kù)發(fā)送SQL語(yǔ)句,需要的朋友可以參考下面文章內(nèi)容2021-09-09基于resty orm的ActiveRecord操作數(shù)據(jù)指南
這篇文章主要為大家介紹了基于resty orm的ActiveRecord操作數(shù)據(jù)指南,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步2022-03-03