@RequestMapping("/list") //分页查询数据 public String list( Integer p, Integer pageSize, Model model) { p = null == p ? 1 : p; //默认显示第一页 pageSize = null == pageSize ? 10 : pageSize; //默认每页显示10条 Page<Student> page = PageHelper.startPage(p, pageSize); List<SystemAdmin> systemAdmins = systemAdminService.list(); SimpleDateFormat sdf1 = new SimpleDateFormat("yyyy-MM-dd HH:mm"); systemAdmins.forEach(systemAdmin -> { systemAdmin.setCreateTimeStr(sdf1.format(systemAdmin.getCreateTime())); }); model.addAttribute("admininfoList", systemAdmins); //绑定接受参数 model.addAttribute("cp", page.getPageNum()); //当前页 model.addAttribute("tp", page.getPages()); //总页数 model.addAttribute("total", page.getTotal()); //总条数 model.addAttribute("pageListURL", "admininfo/list"); //总条数 return "admininfo/admininfoList"; }请详细解释每一行代码
时间: 2023-06-25 08:05:42 浏览: 95
java中对list分页并显示数据到页面实例代码
5星 · 资源好评率100%
1. `@RequestMapping("/list")`: 这是一个Spring MVC注解,用于将请求映射到`/list`路径上的方法上。
2. `public String list(Integer p, Integer pageSize, Model model)`: 这是方法的定义,它接收三个参数:`p`表示当前页码,`pageSize`表示每页显示的记录数,`model`是Spring MVC中的Model对象,用于在视图中传递数据。
3. `p = null == p ? 1 : p;`: 这是一个条件表达式,如果`p`为`null`,则将其赋值为1,否则保持不变。
4. `pageSize = null == pageSize ? 10 : pageSize;`: 如果`pageSize`为`null`,则将其赋值为10,否则保持不变。
5. `Page<Student> page = PageHelper.startPage(p, pageSize);`: 这是MyBatis分页插件PageHelper的使用,它会自动拦截查询语句,生成分页SQL,并执行查询。`startPage(p, pageSize)`方法会返回一个Page对象,它包含了分页查询的结果。
6. `List<SystemAdmin> systemAdmins = systemAdminService.list();`: 这是服务层的调用,用于从数据库中查询所有的系统管理员信息。
7. `SimpleDateFormat sdf1 = new SimpleDateFormat("yyyy-MM-dd HH:mm");`: 这是Java中的日期格式化类,用于将日期类型转换为字符串类型。
8. `systemAdmins.forEach(systemAdmin -> {systemAdmin.setCreateTimeStr(sdf1.format(systemAdmin.getCreateTime()));});`: 这是Java 8中的一个Lambda表达式,它会遍历`systemAdmins`集合,并将每个系统管理员的`createTime`属性转换为字符串类型,并将结果赋值给`createTimeStr`属性。
9. `model.addAttribute("admininfoList", systemAdmins);`: 将查询到的系统管理员信息列表绑定到`admininfoList`属性上,以便在视图中使用。
10. `model.addAttribute("cp", page.getPageNum());`: 将当前页码绑定到`cp`属性上,以便在视图中使用。
11. `model.addAttribute("tp", page.getPages());`: 将总页数绑定到`tp`属性上,以便在视图中使用。
12. `model.addAttribute("total", page.getTotal());`: 将总记录数绑定到`total`属性上,以便在视图中使用。
13. `model.addAttribute("pageListURL", "admininfo/list");`: 将分页查询的URL绑定到`pageListURL`属性上,以便在视图中使用。
14. `return "admininfo/admininfoList";`: 返回视图名称,告诉Spring MVC要渲染哪个视图。
阅读全文