首頁  >  文章  >  web前端  >  ajax怎麼傳遞數組到後台

ajax怎麼傳遞數組到後台

php中世界最好的语言
php中世界最好的语言原創
2018-03-31 15:08:2410026瀏覽

這次帶給大家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[&#39;book_id&#39;] = countsCheckBox[i].value; 
 booksid[i] = mysendbook_id; 
 } 
 //alert(booksid); 
  var confirmdel= confirm(&#39;确认要删除吗?&#39;); 
  if(confirmdel){ 
  //开始请求删除 
   $.ajax({ 
     url:&#39;selectdelbooks&#39;, 
     data:JSON.stringify(booksid), 
     type:&#39;post&#39;, 
     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:

相信看了本文案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章!

推薦閱讀:

如何實作AJAX的分頁效果

怎麼用Ajax提交表單並接收其中的json資料

實作清單無限載入與二級下拉選單選項的Ajax(附程式碼)

以上是ajax怎麼傳遞數組到後台的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn