@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<Repair> repairList = repairService.list(); SimpleDateFormat sdf1 = new SimpleDateFormat("yyyy-MM-dd HH:mm"); repairList.forEach(repair -> { repair.setCreateTimeStr(sdf1.format(repair.getCreateTime())); }); model.addAttribute("repairList", repairList); //绑定接受参数 model.addAttribute("cp", page.getPageNum()); //当前页 model.addAttribute("tp", page.getPages()); //总页数 model.addAttribute("total", page.getTotal()); //总条数 model.addAttribute("pageListURL", "repair/list"); //总条数 return "repair/repairList"; }请详细解释每一行代码
时间: 2023-06-25 21:06:16 浏览: 66
查询数据分页的实现
好的,我来详细解释一下每一行代码的作用:
1. `@RequestMapping("/list")`:定义了一个请求地址为“/list”的映射,表示当用户在浏览器中访问“/list”时,将会执行该方法。
2. `public String list(Integer p, Integer pageSize, Model model)`:定义了一个名为“list”的公共方法,它接受三个参数:整型变量p、整型变量pageSize和Model对象model,并且返回一个字符串类型的值。
3. `p = null == p ? 1 : p;`:如果p为空,则将其设为1,否则保持原值,这一行代码的作用是设置当前页码。
4. `pageSize = null == pageSize ? 10 : pageSize;`:如果pageSize为空,则将其设为10,否则保持原值,这一行代码的作用是设置每页显示的记录数。
5. `Page<Student> page = PageHelper.startPage(p, pageSize);`:使用PageHelper插件的startPage方法,实现分页查询,并将分页信息保存到page对象中。
6. `List<Repair> repairList = repairService.list();`:调用repairService的list方法,获取所有的维修清单列表。
7. `SimpleDateFormat sdf1 = new SimpleDateFormat("yyyy-MM-dd HH:mm");`:创建一个SimpleDateFormat对象,用于格式化日期时间。
8. `repairList.forEach(repair -> {repair.setCreateTimeStr(sdf1.format(repair.getCreateTime()));});`:使用forEach循环遍历repairList中的每个维修清单对象,将其createTime属性格式化为字符串类型,并将格式化后的字符串保存到createTimeStr属性中。
9. `model.addAttribute("repairList", repairList);`:将维修清单列表保存到model对象中,以便在视图中进行渲染。
10. `model.addAttribute("cp", page.getPageNum());`:将当前页码保存到model对象中,以便在视图中进行渲染。
11. `model.addAttribute("tp", page.getPages());`:将总页数保存到model对象中,以便在视图中进行渲染。
12. `model.addAttribute("total", page.getTotal());`:将总记录数保存到model对象中,以便在视图中进行渲染。
13. `model.addAttribute("pageListURL", "repair/list");`:将分页查询的地址保存到model对象中,以便在视图中进行渲染。
14. `return "repair/repairList";`:返回一个名为“repair/repairList”的字符串,表示将会跳转到名为“repairList”的视图页面。
阅读全文