SpringBoot系列(九):解析前端请求“无限嵌套层级的列表数据”

摘要:本文我们将分享介绍后端如何解析快速、高效地解析前端某些奇葩请求中的某些奇葩数据,“无限嵌套的层级列表数据”便是其中的一种,在本文我们将介绍如何奇妙地利用“递归”算法层级遍历并获取相应的层级列表数据,并将其封装成对象,最终将其更新至数据库表中。

内容:正常情况下,后端接口对于前端请求传递过来的数据一般都是了然于胸的,从而在后端接口解析期间,也就知道了前端传递的数据对应的字段的含义,最终也就能“胸有成竹”般的正常解析完。

但有些时候,也存在着一些奇葩情况,如下图所示的“菜单请求传递过来的层级列表数据”:

如果,前端传递过来的只有 id、parentId、name三个字段,那么直接采用某个类实例直接接受即可(这应该没啥难度)!

但是现在多了一个sons,sons里面也是一堆实体,每个实体也包含id、parentId、name三个字段 加一个 sons 列表字段,以此类推下去,即所谓的“无限层级嵌套列表数据”!

此时,如果你采用传统 for 或者 while循环遍历sons进行处理,那是行不通的,不行的话,各位小伙伴可以试试!

为啥不行呢:因为你压根不知道它嵌套了多少层级,而且每个层级里面本身还要再去处理id、parentId、name这样的“父实体”信息,该实体信息下可能还有sons嵌套层级列表数据(简直“疯掉”!)

明人不说暗话,其实,这种数据案例就是一种典型的“汉诺塔”递归实例。下面,我们采用“递归”的思想来实现这种功能续期吧

首先是建立一个请求方法用于接收前端请求中的数据,该请求方法位于BaseController中,如下所示:

@Autowired
    private MenuService menuService;

    @RequestMapping(value = "/menu",method = RequestMethod.POST,consumes = MediaType.APPLICATION_JSON_UTF8_VALUE)
    public BaseResponse menu(@RequestBody MenuDto menuDto){
        BaseResponse response=new BaseResponse(StatusCode.Success);
        try {
            menuService.manageMenu(menuDto);
        }catch (Exception e){
            response=new BaseResponse(StatusCode.Fail.getCode(),e.getMessage());
        }
        return response;
    }

 

更多请见:http://www.mark-to-win.com/tutorial/51035.html 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SpringBoot_Freemarker生成Word_多个表格+两层嵌套循环; 步骤说明: 1.用Microsoft Office Word打开word原件;将文档中需要动态生成的内容,替换为属性名 ${name} 2.另存为,选择保存类型Word 2003 XML 文档(*.xml) 3.用Firstobject free XML editor打开文件,选择Tools下的Indent【或者按快捷键F8】格式化文件内容。左边是文档结构,右边是文档内容; 4. 文档生成后有时需要手动修改,查找第一步中设置的属性名,可能会产生类似${n.....ame}类似的样子,我们将将名字中间的标签删掉,恢复为${name} 5. word模板中有表格,需要循环的位置, 用 标签将第二对 标签(即除表头的w:tr标签后的一对)包围起来 同时表格内的属性例如${name},在这里需要修改为${user.name} (userList是集合在dataMap中的key, user是集合中的每个元素, 类似), 如图: PLUS:若表格之外还有嵌套的循环,也需要用,注意这里的标签不要和某对其他标签交叉,不可以出现这种 6. 标识替换完之后,另存为.ftl后缀文件即可。 代码里是相对有一丢丢复杂的,两层嵌套循环; 总(dataMap) deptName 部门名 list(Table)表的集合 table1(map) table-名字 ${map.table} tableName-中文名 ${map.tableName} columnCount-字段数 ${map.columnCount} recordCount-记录数 ${map.recordCount} listA-List--表格1 map.listA column Model属性——字段名 ${model.column} columnName Model属性——字段中文名 ${model.column} rate Model属性——字段占比 ${model.rate} nullValueCount Model属性——字段空值数 ${model.nullValueCount} listB-List--表格2 map.listB …… listC-List--表格3 map.listC …… table2 table-名字 ${map.table} tableName-中文名 ${map.tableName} columnCount-字段数 ${map.columnCount} recordCount-记录数 ${map.recordCount} listA-List--表格1 map.listA column Model属性——字段名 ${model.column} columnName Model属性——字段中文名 ${model.column} rate Model属性——字段占比 ${model.rate} nullValueCount Model属性——字段空值数 ${model.nullValueCount} listB-List--表格2 map.listB …… listC-List--表格3 map.listC …… table3 ……
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值