ajax传递参数给springmvc总结[转]
通過(guò)ajax傳遞參數(shù)給springmvc,經(jīng)常會(huì)因?yàn)?參數(shù)類(lèi)型太復(fù)雜,或者根本不知道springmvc都支持哪些類(lèi)型轉(zhuǎn)換,導(dǎo)致后臺(tái)接收出現(xiàn)各種問(wèn)題。如果書(shū)寫(xiě)格式?jīng)]有問(wèn)題仍然接受參數(shù)報(bào)錯(cuò),大部分是因?yàn)閟pringmvc默認(rèn)無(wú)法支持該種格式的json轉(zhuǎn)換導(dǎo)致的
現(xiàn)在一句話(huà)解決,就是用@RequestBody注解接收
下面看一些傳參的例子,基本涵蓋了大部分的參數(shù)傳遞類(lèi)型
案例1:簡(jiǎn)單數(shù)組 idList[]
ajax
$("#test1").on("click",function(){var idList = new Array();idList.push("1");idList.push("2");idList.push("3");$.post("/mvc/client1/test1",{idList:idList})});?
java
/*** 簡(jiǎn)單類(lèi)型list* explain:包含string int date 等屬性*/@RequestMapping("/test1")@ResponseBodypublic void test1(@RequestParam("idList[]") List<Integer> idList){for(Integer i: idList){System.out.println(i);}}?
案例1中要注意,當(dāng)你ajax傳遞一個(gè)很簡(jiǎn)單的數(shù)組,本以為后臺(tái)能夠接受到,卻總是報(bào)錯(cuò),很可能的原因是:http請(qǐng)求傳遞數(shù)組的時(shí)候,為了區(qū)別是一個(gè)數(shù)組,會(huì)在數(shù)組名稱(chēng)后面加上中括號(hào)“[]”,所以后臺(tái)接受的時(shí)候用@RequestParam告訴方法,你要的idList實(shí)際上是idList[]就可以了
案例:2:簡(jiǎn)單對(duì)象User (包含id,username)
ajax
$("#test2").on("click",function(){var id =1;var username ="fangxin";$.post("/mvc/client1/test2",{id:id,username:username,birthday:new Date()})});?
java
@RequestMapping("/test2")@ResponseBodypublic void test2(User user){System.out.println(user.getId());System.out.println(user.getUsername());System.out.println(user.getBirthday());}?
這就是最常見(jiàn)的傳遞參數(shù),如果一個(gè)對(duì)象的屬性都是簡(jiǎn)單類(lèi)型,那基本沒(méi)什么問(wèn)題
案例3:復(fù)雜對(duì)象User (包含id,username,String[],List<Person>)
ajax
$("#test3").on("click",function(){var user = {id:1,username:"fangxin",birthday:new Date(),luckyNums:[1,2,3],friends:[{name:"zhangsan"},{name:"lisi"}]};$.ajax({type: "POST",url:"/mvc/client1/test3",data: JSON.stringify(user),contentType:"application/json"})});?
java
/*** 復(fù)雜對(duì)象* explain:包含簡(jiǎn)單list屬性、對(duì)象list屬性*/@RequestMapping("/test3")@ResponseBodypublic void test3(@RequestBody User user){System.out.println(user.getId());System.out.println(user.getUsername());System.out.println(user.getBirthday());for(Integer i:user.getLuckyNums()){System.out.println(i);}for(Person p:user.getFriends()){System.out.println(p.getName());}}?
案例3中的User的屬性相當(dāng)復(fù)雜,有簡(jiǎn)單數(shù)組,還有包含對(duì)象的復(fù)雜List,這樣的user如果用案例2的方式接受,肯定就掛了。此時(shí),最好是前臺(tái)stringify轉(zhuǎn)換成json字符串,后臺(tái)用@RequestBody接受自動(dòng)轉(zhuǎn)換成想要的數(shù)據(jù)格式。
案例4:復(fù)雜List<User>
ajax
$("#test5").on("click",function(){var users = [];for(var i=0;i<10;i++){var user = {id:1,username:"fangxin",birthday:new Date(),luckyNums:[1,2,3],friends:[{name:"zhangsan"},{name:"lisi"}]};users.push(user);}$.ajax({type: "POST",url:"/mvc/client1/test5/",data: JSON.stringify(users),contentType:"application/json"})});?
java
/*** 復(fù)雜List*/@RequestMapping("/test5")@ResponseBodypublic void test5(@RequestBody List<User> users){for(User user:users){System.out.println(user.getUsername());}}?
用案例3的方式,依然可以接收到,屢試不爽。
案例5 List<Map<String,Obj>>更復(fù)雜對(duì)象
同理
轉(zhuǎn)載于:https://www.cnblogs.com/franson-2016/p/6770028.html
與50位技術(shù)專(zhuān)家面對(duì)面20年技術(shù)見(jiàn)證,附贈(zèng)技術(shù)全景圖總結(jié)
以上是生活随笔為你收集整理的ajax传递参数给springmvc总结[转]的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: OpenCV 玩九宫格数独(二):knn
- 下一篇: c++ STL 容器——序列