這次帶給大家Ajax Struts2接收陣列表單(附程式碼),Ajax Struts2接收陣列表單的注意事項有哪些,以下就是實戰案例,一起來看一下。
下面我將透過普通表單和ajax兩種方式講解。首先我們有以下一個實體,一個action和一個jsp。
Student.java
public class Student { private String name; private String num; } StudentAction.java public class StudentAction extends ActionSupport { private List<Student> lstStu; }
xy.jsp
<script type="text/javascript"> var stus = []; stus.push({num:"1",name:"xy1"}); stus.push({num:"2",name:"xy2"}); stus.push({num:"3",name:"xy3"}); </script>
下面開始吧,以下程式碼都是寫在xy. jsp的腳本區的。
普通表單形式-遍歷陣列,建構表單隱藏域
var htmlContent = ""; for(var i=0;i<stus.length;i++){ htmlContent += "<input type='hidden' name='lstStu[" + i + "].name' value='" + stus[i].name + " ' />"; htmlContent += "<input type='hidden' name='lstStu[" + i + "].num' value='" + stus[i].num + " ' />"; }
特殊情況
<input type='hidden' name='lstStu.name' value='xy1' /> <input type='hidden' name='lstStu.name' value='xy2' /> <input type='hidden' name='lstStu.name' value='xy3' />
傳單一屬性時,struts可以認識,表示3個不同的student。但傳送兩個屬性就不行了,因為struts不知道組合。不推薦。
ajax形式-遍歷數組,建構json物件
var param = {}; for(var i=0;i<stus.length;i++){ param["lstStu[" + i + "].name"] = stus[i].name; param["lstStu[" + i + "].num"] = stus[i].num; } $.ajax({ data:param });
其實我們建構了這樣一個json物件
data:{ lstStu[0].num:"1",lstStu[0].name:"xy1", lstStu[1].num:"2",lstStu[1].name:"xy2", lstStu[2].num:"3",lstStu[0].name:"xy3" }
相信看了本文案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章!
推薦閱讀:
#以上是Ajax+Struts2接收陣列表單(附程式碼)的詳細內容。更多資訊請關注PHP中文網其他相關文章!