欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

通过Ajax两种方式讲解Struts2接收数组表单的方法

程序员文章站 2022-06-09 10:13:29
使用struts2表单传值,可以传一个或者是作为一个对象的各个属性传,都非常灵活便捷。但是如果我们需要传一个数组并希望struts正确接收,该怎么处理呢? 下面我将通过普...

使用struts2表单传值,可以传一个或者是作为一个对象的各个属性传,都非常灵活便捷。但是如果我们需要传一个数组并希望struts正确接收,该怎么处理呢?

下面我将通过普通表单和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"
}

有的人说,那直接把stus数组作为data传到action不是很方便?答案是不能这样传,这样action接收不到或者说struts不知道怎么处理传来的数组。

本文内容到此结束了,希望对大家有所帮助。