趁热打铁再来一个递归调用,也是前后端对接的需求,前端页面可以展开table里的某一行,需满足多层级关系,因此解决该问题,以递归的方式处理更为方便,页面需求如下: 展开前:
展开后:
蓝色圈出的部分可视为子table,即子节点,子节点也可以展开,以此类推。。。可以无限递归下去。
代码:
实体类
持久层用的是jpa,实现自关联比较方便。
服务类
(1)DTO
(2)查询记录
直接查询父级节点,因为自关联时子节点已经挂在父级下面。
(3)遍历
buildApiParamDTO()方法为实体类与DTO的转化。
(4)递归
apiParamDTOList为最为层的list,apiParamDTO为遍历到的当前节点,apiParamDTOs为apiParamDTO的子节点。
递归子节点,用到递归最重要的一点就是要有一个退出递归的条件。因此,我们这里首先要判断子节点是否存在,不存在则直接退出,不要递归,否则继续;因为子节点也是集合合,具体逻辑如下:
第一步:遍历子节点,我这里用了java8的stream流更方面的实现;
第二步:映射,在转换的时候,首先要获取当前节点childApiParamDTO,当前节点childApiParamDTO也可能是父节点,然后对当前节点进行递归调用,获取转换后的childApiParamDTOs,childApiParamDTOs是childApiParamDTO的子节点,调用setChildApiParamDTOs()方法。
第三部:将转换后的Set返回到外层,调用set方法。
效果:
"list":[
{
"type":"REQ_PARAM",
"param_name":"userName",
"param_type":"String",
"required":true,
"max_length":64,
"param_desc":"用户名16",
"sample_value":"张三",
"child_params":[
{
"type":"REQ_PARAM",
"param_name":"age",
"param_type":"int",
"required":true,
"max_length":0,
"param_desc":"年龄44",
"sample_value":"26",
"child_params":[
{
"type":"REQ_PARAM",
"param_name":"age",
"param_type":"int",
"required":true,
"max_length":0,
"param_desc":"年龄48",
"sample_value":"26"
},
{
"type":"REQ_PARAM",
"param_name":"age",
"param_type":"int",
"required":true,
"max_length":0,
"param_desc":"年龄49",
"sample_value":"26"
}
]
},
{
"type":"REQ_PARAM",
"param_name":"age",
"param_type":"int",
"required":true,
"max_length":0,
"param_desc":"年龄17",
"sample_value":"26"
}
]
},
{
"type":"REQ_PARAM",
"param_name":"userName",
"param_type":"String",
"required":true,
"max_length":64,
"param_desc":"用户名45",
"sample_value":"张三"
}
]
作者:songrenwei
链接:https://juejin.cn/post/6985054966448652302
来源:掘金
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。