文章目录
批量操作
什么时候前台页面会传数组给后台?
- 复选框标签
- 有两种接收方式
SpringMVC批量删除操作
(1)数组参数绑定
数组
- QueryOV对象
(2)前台代码
多个复选框表单,并把复选框选中的内容,发给给服务器后台,服务器去接收
- demo01_array.jsp
<%-- 页面会将选中的复选框的值,需要让复选框使用同一个name
程序认为需要将多个值 放到数组中,提交到后台
--%>
<form method="post" action="${pageContext.request.contextPath}/delete1.action">
<input type="checkbox" value="1" name="ids"/> 第 1条记录<br/>
<input type="checkbox" value="2" name="ids"/> 第 2条记录<br/>
<input type="checkbox" value="3" name="ids"/> 第 3条记录<br/>
<input type="submit" value="提交数据到后台" > <br/>
</form>
(3)后台代码
页面如果是提交的复选框的数据,则返回的是数组,需要使用数组来接收
- Demo01Controller.java
@Controller
public class Demo01Controller {
@RequestMapping("delete1.action")
public ModelAndView test01(Integer[] ids){
//参数只需要写数组
System.out.println(Arrays.toString(ids));
return null;
}
}
- QueryOV对象绑定
(1)定义一个新类,类中定义一个数组成员变量
public class A{
private 数据类型[] 变量名;
}
(2)前台代码
表单 带 复选框,复选框使用同一个name
(3)后台代码
方法参数为 新定义类
- MyQueryOV.java
public class MyQueryOv {
private Integer[] ids;
public Integer[] getIds() {
return ids;
}
public void setIds(Integer[] ids) {
this.ids = ids;
}
}
- Demo01Controller.java
@RequestMapping("delete2.action")
public ModelAndView test02(MyQueryOv ov){
//参数只需要写QueryOV类
System.out.println(Arrays.toString(ov.getIds()));
return null;
}
(4)注意
这里形参数组的名字必须和表单复选框的name属性的值一致
SpringMVC批量更新操作
参数绑定-集合传递
- (1)什么时候前台会给后台传集合?
批量修改,将修改的多条记录放到集合中提交给后台。 - (2)前台代码
》批量修改 使用input标签显示数值
重点在 参数名 与 varStatus - (3)后台代码
(1)页面批量修改数据
- demo03_update_persons.jsp
<%--
表单 只会将多条记录放到一个list里面,提交到后台
--%>
<form method="post" action="${pageContext.request.contextPath}/update3.action">
<table>
<tr>
<td><input type="hidden" value="1" name="list[0].id" /></td>
<td><input type="text" value="jack" name="list[0].username" /></td>
<td><input type="text" value="1234" name="list[0].password" /></td>
</tr>
<tr>
<td><input type="hidden" value="2" name="list[1].id" /></td>
<td><input type="text" value="rose" name="list[1].username" /></td>
<td><input type="text" value="1234" name="list[1].password" /></td>
</tr>
</table>
<input type="submit" value="提交数据到后台" > <br/>
</form>
- MyQueryOv2.java
public class MyQueryOv2 {
private List<Person> list;
public List<Person> getList() {
return list;
}
public void setList(List<Person> list) {
this.list = list;
}
}
- Person.java
public class Person {
private Integer id;
private String username;
private String password;
}
- test03
@RequestMapping("update3.action")
public ModelAndView test03(MyQueryOv2 ov){
//参数写QueryOv2类,但是页面要指定变量名与索引
System.out.println(ov.getList());
return null;
}
- 如果是数组 ,参数可以写数组也可以写QueryOv类,但是如果是List,参数位置只能写QueryOV类
(2)批量修改页面的回显
@RequestMapping 注解
-
path或者value表示地址
-
method 请求方式 get/post
-
test04
@RequestMapping(path = "updateUI.action",method = {
RequestMethod.POST,RequestMethod.GET})//回显页面
public ModelAndView test04(){
//
Person p1 = new Person(1,"jack","1234");
Person p2 = new Person(2,"rose","1234");
List<Person> list = new ArrayList<Person>();
list.add(p1);
list.add(p2);
//使用ModelAndView实现请求转发
ModelAndView mv = new ModelAndView();
mv.addObject("list",list);
mv.setViewName("demo04_update_persons");
return mv;
}
- demo04_update_persons.jsp
<%@ page contentType="text/html;charset=UTF-8" language="java" isELIgnored="false" %>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<html>
<head>
<title>Title</title>
</head>
<body>
<%--
表单 只会将多条记录放到一个list里面,提交到后台
--%>
<form method="post" action="${pageContext.request.contextPath}/update3.action">
<table>
<c:forEach items="${list}" var="person" varStatus="vs">
<tr>
<td><input type="hidden" value="${person.id}" name="list[${vs.index}].id" /></td>
<td><input type="text" value="${person.username}" name="list[${vs.index}].username" /></td>
<td><input type="text" value="${person.password}" name="list[${vs.index}].password" /></td>
</tr>
</c:forEach>
</table>
<input type="submit" value="提交数据到后台" > <br/>
</form>
</body>
</html>
(3)varStatus
(1) varStatus 表示状态 对象 包含
- count 是集合的元素个数
- index 是索引
for( int index = 0;index<list.size();index++){
}