SpringMVC如何接收引數各種場景
阿新 • • 發佈:2021-11-02
目錄
- 表單提交
- 表單提交二
- 後臺程式碼接收方式一
- 後臺程式碼接收方式二
表單提交
此處的表單時 -使用ON.stringify()函式將陣列轉換成json型別提交後臺,後臺使用@RequestBody User user接受處理
頁面js
//新增提交按鈕 $("#buildsubmit").click(function() { var param = $(".form").serializeJson(); $.ajax({ type: 'post',url: path + "/web/member/save.do",contentType: "application/json",dataType: 'json',data: JSON.stringify(param),success: function(data) { },}); } });
後端程式碼
@RequestMapping(value = "/save",method = RequestMethod.POST) public GeneralResponse save(@RequestBody @Valid MemberInsertDetail member,BindingResult bindingResult) throws JsonProcessingException { if (bindingResult.hasErrors()) { throw new ErrParamException(); } boolean flag = false; flag = memberService.save(member); }
表單提交二
使用.serialize()方法 提交表單內容;
1、可以後臺使用 request.getParamter("對應欄位的name")獲取引數;
2、也可以使用 Model mdel 的POJO接受。(name要一一對應起來)
- 格式:var data = $("#formID").serialize();
- 功能:將表單內容序列化成一個以&拼接的字串,鍵值對的形式,name1=val1&name2=val2&,空格以%20替換。
頁面JS
function sub(){ $.ajax({ type:"post",url:"/restaurant/addEmployees.do",data:$("#form").serialize(),dataType :"json",success:function(data){ if(!data.success){ } }); }
頁面html程式碼:
<form action="" id="staff_form"> <div class="addInfor"> <input type="" name="phone" id="phone" value="" placeholder="請輸入手機號"/> <input type="" name="password" id="password" value="" placeholder="請輸入密碼"/> <input type="" name="username" id="username" value="" placeholder="請輸入姓名"/> <input name="checkbox" value="chief_store_member" type="checkbox" > <label class="grey-font" >多店管理</label> <input name="checkbox" value="branch_store_member" type="checkbox"> <label class="grey-font" >單店管理</label> </div> <button type="button" class="mui-btn orange-btn" nclick="sub();">確認</button> </form>
後臺程式碼接收方式一
含有單個的checkbox引數接收
@RequestMapping("/addEmployees") @ResponseBody public Result<Integer> addEmployees(HttpServletRequest request) { String phone = request.getParameter("phone"); String password = request.getParameter("password"); String username = request.getParameter("username"); 身份單checkbox接收。如果是複選框多個checkbox,則用陣列String[] 接收。 String checkbox = request.getParameter("checkbox"); }
後臺程式碼接收方式二
@RequestMapping(value="/addCustomer",method=RequestMethod.POST) @ResponseBody public LogisticsResult addCustomer(@Valid CustomerInfo customer,BindingResult result ){ 如果是複選框多個checkbox,則在pojo中 用與checkbox的name一樣的 陣列接收。 如: String[] checkbox; }
接收List<String>集合引數:
1、頁面js程式碼:
var idList = new Array(); idList.push(“1”); idList.push(“2”); idList.push(“3”); var isBatch = false; $.ajax({ type: "POST",url: "<%=path%>/catalog.do?fn=deleteCatalogSchemes",data: {"idList":idList,"isBatch":isBatch},success: function(data){ … },error: function(res){ … } });
2、Controller方法:
@ContrcdFJhFFKoller @RequestMapping("/catalog.do") public class CatalogController { @RequestMapping(params = "fn=deleteCatalogSchemes") @ResponseBody public AjaxJson deleteCatalogSchemes(@RequestParam("idList[]") List<String> idList,Boolean isBatch) { … } }
接收List<User>、User[]集合引數:
1、User實體類:
public class User { private String name; private String pwd; //省略getter/setter }
2、頁面js程式碼:
var userList = new Array();
userList.push({name: "李四",pwd: "123"});
userList.push({name: "張三",pwd: "332"});
$.ajax({
type: "POST",url: "<%=path%>/catalog.do?fn=saveUsers",data: JSON.stringify(userList),//將物件序列化成JSON字串
dataType:"json",contentType : 'application/json;charset=utf-8',//設定請求頭資訊
success:http://www.cppcns.com function(data){
…
},error: function(res){
…
}
});
3、Controller方法:
@Controller @RequestMapping("/catalog.do") public class CatalogController { @RequestMapping(params = "fn=saveUsers") @ResponseBody public AjaxJson saveUsers(@RequestBody List<User> userList) { … } }
如果想要接收User[]陣列,只需要把saveUsers的引數型別改為@RequestBody User[] userArray就行了。
接收List<Map<String,Object>>集合引數cdFJhFFK:
1、頁面js程式碼(不需要User物件了):
var userList = new Array();
userList.push({name: "李四",url: "&http://www.cppcns.comlt;%=path%>/catalog.do?fn=saveUsers",//設定請求頭資訊
success: function(data){
…
},error: function(res){
…
}
});
2、Controller方法:
@Controller @RequestMapping("/catalog.do") public class CatalogController { @RequestMapping(params = "fn=saveUsers") @ResponseBody public AjaxJson saveUsers(@RequestBody List<Map<String,Object>> listMap) { … } }
接收User(bean裡面包含List)集合引數:
1、User實體類:
public class User { private String name; private String pwd; private List<User> customers;//屬於使用者的客戶群 //省略getter/setter }
2、頁面js程式碼:
var customerArray = new Array(); customerArray.push({name: "李四",pwd: "123"}); customerArray.push({name: "張三",pwd: "332"}); var user = {}; user.name = "李剛"; user.pwd = "888"; user. customers = customerArray; $.ajax({ type: "POST",data: JSON.stringify(user),error: function(res){ … } });
3、Controller方法:
@Controller @RequestMapping("/catalog.do") public class CatalogController { @RequestMapping(params = "fn=saveUsers") @ResponseBody public AjaxJson saveUsers(@RequestBody User user) { List<User> customers = user.getCustomers(); … } }
以上為個人經驗,希望能給大家一個參考,也希望大家多多支援我們。