套餐信息分页查询——后端

1.交互逻辑

页面发送ajax请求,将分页查询参数(page, pageSize, name)提交到服务端,获取分页数据;页面发送请求,请求服务端进行图片下载,用于页面图片展示。

2.代码逻辑

需要注意,Setmeal中只有套餐的Id,没有套餐的名称,因此,在返回分页数据的时候,要额外把套餐的名称带上,即用封装的对象SetmealDto。

java 复制代码
    /**
     * 套餐分页查询
     * @param page
     * @param pageSize
     * @param name
     * @return
     */
    @GetMapping("/page")
    public R<Page> page(int page, int pageSize, String name){
        //分页构造器对象
        Page<Setmeal> pageInfo = new Page<>(page, pageSize);
        Page<SetmealDto> dtoPage = new Page<>();

        LambdaQueryWrapper<Setmeal> queryWrapper = new LambdaQueryWrapper<>();
        //添加查询条件, 根据name进行模糊查询
        queryWrapper.like(name != null, Setmeal::getName, name);
        //添加排序条件
        queryWrapper.orderByDesc(Setmeal::getUpdateTime);

        setmealService.page(pageInfo, queryWrapper);

        //进行对象的拷贝
        BeanUtils.copyProperties(pageInfo, dtoPage, "records");
        List<Setmeal> records = pageInfo.getRecords();

        List<SetmealDto> list = records.stream().map((item) -> {
            SetmealDto setmealDto = new SetmealDto();
            //对象拷贝
            BeanUtils.copyProperties(item, setmealDto);
            //分类id
            Long categoryId = item.getCategoryId();
            //根据id拿到分类名称
            Category category = categoryService.getById(categoryId);
            if(category != null){
                //分类名称
                String categoryName = category.getName();
                setmealDto.setCategoryName(categoryName);
            }
            return setmealDto;
        }).collect(Collectors.toList());

        dtoPage.setRecords(list);
        return R.success(dtoPage);
    }
相关推荐
勇哥java实战分享3 小时前
程序员的明天:AI 时代下的行业观察与个人思考
后端
掘金码甲哥5 小时前
超性感的轻量级openclaw平替,我来给你打call
后端
用户8356290780518 小时前
无需 Office:Python 批量转换 PPT 为图片
后端·python
啊哈灵机一动8 小时前
使用golang搭建一个nes 模拟器
后端
日月云棠9 小时前
各版本JDK对比:JDK 25 特性详解
java
间彧9 小时前
SpringBoot + ShardingSphere 读写分离实战指南
后端
砍材农夫9 小时前
订单超时
后端
树獭叔叔10 小时前
06-大模型如何"学习":从梯度下降到AdamW优化器
后端·aigc·openai
用户83071968408210 小时前
Spring Boot 项目中日期处理的最佳实践
java·spring boot
得鹿10 小时前
MySQL基础架构与存储引擎、索引、事务、锁、日志
后端