這篇文章主要為大家介紹了關於利用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<jsonarr.length();i++){ book_id.add(((JSONObject)jsonarr.get(i)).getString("book_id")); }...</span>
#這樣我們得到一個list,裡面有我們選取的id值。
資料庫中資訊:
頁面的多重選擇:
後台得到的選擇的book的id:
這樣拿到id的集合,那後面的運算就方便了。
上面是我整理給大家的,希望今後對大家有幫助。
相關文章:
#配置Chrome支援本地(file協定)的AJAX請求(圖文教學)
#
以上是利用ajax傳遞數組及後台接收的方法詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!