利用ajax傳遞數(shù)組及后臺(tái)接收的方法詳解
前言
我們?cè)谑褂胊jax異步的提交多選框得到需要操作的對(duì)象的id,這時(shí)我們可以把每一個(gè)id做出一個(gè)對(duì)象,之后放到一個(gè)數(shù)組中,再使用JSON.stringify()
對(duì)這個(gè)數(shù)組進(jìn)行json的格式化;在后臺(tái)中再inputStream中解析出我們的json字符串,之后只用:
new JSONArray()
得到j(luò)son數(shù)組,循環(huán)解析我們想要的屬性:
var countsCheckBox = $("input[type='checkbox']:checked"); var booksid = []; for(var i=0;i<countsCheckBox.length;i++){ //使用[]取得元素是是一個(gè)domElement元素,取值需要使用.value, //如果使用countsCheckBox.eq(i) 則是一個(gè)Obkject元素,就可以使用val()取值 //alert(countsCheckBox[i].value); mysendbook_id = {}; mysendbook_id['book_id'] = countsCheckBox[i].value; booksid[i] = mysendbook_id; } //alert(booksid); var confirmdel= confirm('確認(rèn)要?jiǎng)h除嗎?'); if(confirmdel){ //開(kāi)始請(qǐng)求刪除 $.ajax({ url:'selectdelbooks', data:JSON.stringify(booksid), type:'post', success:function(res){ alert("刪除成功"); location.replace("/TheDemo/books/pageBooksShow"); } }); }
上面的js中我們把每一個(gè)選中的id放到一個(gè)mysendbook_id的“book_id”的屬性中,再把這個(gè)對(duì)象放到booksid的數(shù)組中;到發(fā)送異步請(qǐng)求時(shí)使用
JSON.stringify(bookid)
格式化這個(gè)booksid數(shù)組,得到一個(gè)json的數(shù)組。
再看后臺(tái)我們?cè)趺唇邮眨?/strong>
一個(gè)是做一個(gè)類里面有一個(gè)list,這個(gè)list裝的是只有一個(gè)屬性為bookid的類,再使用注解@RequestBody
加到這個(gè)形參上。但是這樣比較麻煩;
還有一種是從輸入流里面獲取數(shù)據(jù),使用IOUtils.toString
把inputStream轉(zhuǎn)為字符串,再使用new JSONArray(mybooksid);
得到這個(gè)json數(shù)組
從而得到每一個(gè)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>
這樣我們得到一個(gè)list,里面有我們選中的id值。
數(shù)據(jù)庫(kù)中信息:
頁(yè)面的多選:
后臺(tái)得到的選擇的book的id:
這樣拿到id的集合,那后面的操作就方便了。
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)腳本之家的支持。
相關(guān)文章
基于h5的history改善ajax列表請(qǐng)求體驗(yàn)
這篇文章主要介紹了基于h5的history改善ajax列表請(qǐng)求體驗(yàn)的相關(guān)資料,需要的朋友可以參考下2015-11-11AJAX+JSP實(shí)現(xiàn)讀取XML內(nèi)容并按排列顯示輸出的方法示例
這篇文章主要介紹了AJAX+JSP實(shí)現(xiàn)讀取XML內(nèi)容并按排列顯示輸出的方法,結(jié)合實(shí)例形式分析了ajax與后臺(tái)jsp頁(yè)面交互實(shí)現(xiàn)xml內(nèi)容的排列輸出相關(guān)操作技巧,需要的朋友可以參考下2018-06-06ajax動(dòng)態(tài)為a標(biāo)簽href賦值不執(zhí)行跳轉(zhuǎn)的原因分析及解決
ajax 動(dòng)態(tài)為a標(biāo)簽的href屬性賦值,總是不執(zhí)行跳轉(zhuǎn)的原因想必大家有遇到過(guò)吧,下面與大家分享下具體的解決方法,希望對(duì)你有所幫助2013-06-06ajax實(shí)現(xiàn)數(shù)據(jù)分頁(yè)查詢
這篇文章主要為大家詳細(xì)介紹了ajax實(shí)現(xiàn)數(shù)據(jù)分頁(yè)查詢的相關(guān)資料,以及ajax實(shí)現(xiàn)對(duì)數(shù)據(jù)庫(kù)的查詢,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-02-02Ajax實(shí)現(xiàn)動(dòng)態(tài)加載組合框的實(shí)例代碼
本文通過(guò)實(shí)例代碼給大家介紹了Ajax實(shí)現(xiàn)動(dòng)態(tài)加載組合框功能,感興趣的朋友一起看看吧2017-08-08SSH網(wǎng)上商城之使用ajax完成用戶名是否存在異步校驗(yàn)
這篇文章主要介紹了SSH網(wǎng)上商城之使用ajax完成用戶名是否存在異步校驗(yàn)的相關(guān)資料,需要的朋友可以參考下2015-12-12[ASP.NET Ajax] ECMAScript基礎(chǔ)類以及Asp.net Ajax對(duì)類<Object&a
[ASP.NET Ajax] ECMAScript基礎(chǔ)類以及Asp.net Ajax對(duì)類<Object>的擴(kuò)展...2007-01-01那些年,我還在學(xué)習(xí)Ajax 學(xué)習(xí)筆記
Ajax不用說(shuō),每個(gè)做web開(kāi)發(fā)的同志都知道,因?yàn)樗菍W(xué)習(xí)web開(kāi)發(fā)必經(jīng)之路,不管你是做asp.net,還是javaWeb,還是PHP2012-03-03