您好,欢迎访问一九零五行业门户网

ajax怎样传递数组到后台

这次给大家带来ajax怎样传递数组到后台,ajax传递数组到后台的注意事项有哪些,下面就是实战案例,一起来看一下。
前言
我们在使用ajax异步的提交多选框得到需要操作的对象的id,这时我们可以把每一个id做出一个对象,之后放到一个数组中,再使用json.stringify()对这个数组进行json的格式化;在后台中再inputstream中解析出我们的json字符串,之后只用:
new jsonarray()得到json数组,循环解析我们想要的属性:
var countscheckbox = $(input[type='checkbox']:checked);   var booksid = [];   for(var i=0;i<countscheckbox.length;i++){ //使用[]取得元素是是一个domelement元素,取值需要使用.value, //如果使用countscheckbox.eq(i) 则是一个obkject元素,就可以使用val()取值 //alert(countscheckbox[i].value); mysendbook_id = {}; mysendbook_id['book_id'] = countscheckbox[i].value; booksid[i] = mysendbook_id; } //alert(booksid); var confirmdel= confirm('确认要删除吗?'); if(confirmdel){ //开始请求删除 $.ajax({ url:'selectdelbooks', data:json.stringify(booksid), type:'post', success:function(res){ alert("删除成功"); location.replace("/thedemo/books/pagebooksshow"); } }); }
上面的js中我们把每一个选中的id放到一个mysendbook_id的“book_id”的属性中,再把这个对象放到booksid的数组中;到发送异步请求时使用
json.stringify(bookid)格式化这个booksid数组,得到一个json的数组。
再看后台我们怎么接收:
一个是做一个类里面有一个list,这个list装的是只有一个属性为bookid的类,再使用注解@requestbody加到这个形参上。但是这样比较麻烦;
还有一种是从输入流里面获取数据,使用ioutils.tostring 把inputstream转为字符串,再使用new jsonarray(mybooksid);得到这个json数组
从而得到每一个json中的book_id的属性值
<span style="font-family:simsun;font-size: 10.5pt;"> </span><span style="font-family:kaiti_gb2312;font-size:14px;"> @requestmapping(selectdelbooks)   public string selectdelbooks(httpservletrequest request) throws exception {    servletinputstream inputstream = request.getinputstream();    string mybooksid = ioutils.tostring(inputstream);    jsonarray jsonarr = new jsonarray(mybooksid);    list<string> book_id =new arraylist<string>();    for (int i=0;i 这样我们得到一个list,里面有我们选中的id值。
数据库中信息:
页面的多选:
后台得到的选择的book的id:
相信看了本文案例你已经掌握了方法,更多精彩请关注其它相关文章!
推荐阅读:
如何实现ajax的分页效果
怎样用ajax提交表单并接收其中的json数据
实现列表无限加载与二级下拉菜单选项的ajax(附代码)
以上就是ajax怎样传递数组到后台的详细内容。
其它类似信息

推荐信息