轉載自:http://blog.csdn.net/foyui001/article/details/47263383
在使用SpringMvc框架開發時,遇到如何將頁面的List傳入后台的問題,查找多方資料,得到以下答案:(經驗證,好使!)
實例:
在JSP頁面定義如下:
<script>
function submit(){
alert(1);
$.ajax({
url:'${ctx}/test.do',
type:'POST',
data:$('form').serialize(),
dataType:'json',
success:function(data){
alert("成功!");
}
});
}
</script>
<form id="form">
<input type="text" name="user[0].userName" value="jobs"/>
<input type="text" name="user[0].password" value="55"/><br/>
<input type="text" name="user[1].userName" value="jim"/>
<input type="text" name="user[1].password" value="21"/><br/>
</form>
<button onclick="submit()">提交</button>
再寫<button>時,要將button放在form外面,如果放在form里面,會默認執行<form action="">方法,即使你沒定義,他也會執行,最好放在外面,或者你用<form action="test/test.do">方式提交數據;
錯誤寫法:如果我們直接在Controller中如下寫;
@RequestMapping(value='/test.do")
public void test(List<User> usr){}
會報無法實例化List<User>的錯誤!
正確寫法:
在后台設定一個類,PersonList類:
public class PersonList {
private List<User> user;
public List<User> getUser(){
return user;
}
public void setUser(List<User> user){
this.user=user;
}
}
在Controller中如下:
@RequestMapping(value="/test.do")
public void test(PersonList user){
String name = user.getUser().get(0).getUserName();
System.out.println(name);
}
這樣我們就可以得到,頁面傳過來的List了!
注意點:JSP頁面上的name="user[0].password"應該與PersonList中的屬性名保持一致;