写点什么

Java 递归实现评论多级回复

作者:Jeremy Lai
  • 2022-12-01
    广东
  • 本文字数:1191 字

    阅读完需:约 4 分钟

最近工作需要做一个评论功能,除了展示评论之外,还需要展示评论回复,评论的回复的回复,这里就用到了递归实现评论的多级回复

评论实体

数据库存储字段: id 评论 id、parent_id 回复评论 id、message 消息。其中如果评论不是回复评论,parent_id-1


创建一个评论实体 Comment


public class Comment {
/** * id */ private Integer id;
/** * 父类id */ private Integer parentId;
/** * 消息 */ private String message;}
复制代码


查询到所有的评论数据。方便展示树形数据,对Comment添加回复列表


List<ViewComment> children


ViewComment结构如下:


// 展示树形数据public class ViewComment {
/** * id */ private Integer id;
/** * 父类id */ private Integer parentId;
/** * 消息 */ private String message;
/** * 回复列表 */ private List<ViewComment> children = new ArrayList<>();}
复制代码

添加非回复评论

非回复评论的parent_id-1,先找到非回复评论:


List<ViewComment> viewCommentList = new ArrayList<>();// 添加模拟数据Comment comment1 = new Comment(1,-1,"留言1");Comment comment2 = new Comment(2,-1,"留言2");Comment comment3 = new Comment(3,1,"留言3,回复留言1");Comment comment4 = new Comment(4,1,"留言4,回复留言1");Comment comment5 = new Comment(5,2,"留言5,回复留言2");Comment comment6 = new Comment(6,3,"留言6,回复留言3");
//添加非回复评论for (Comment comment : commentList) { if (comment.getParentId() == -1) { ViewComment viewComment = new ViewComment(); BeanUtils.copyProperties(comment,viewComment); viewCommentList.add(viewComment); }}
复制代码

递归添加回复评论

遍历每条非回复评论,递归添加回复评论:


for(ViewComment viewComment : viewCommentList) {    add(viewComment,commentList);}

private void add(ViewComment rootViewComment, List<Comment> commentList) { for (Comment comment : commentList) { // 找到匹配的 parentId if (rootViewComment.getId().equals(comment.getParentId())) { ViewComment viewComment = new ViewComment(); BeanUtils.copyProperties(comment,viewComment); rootViewComment.getChildren().add(viewComment); //递归调用 add(viewComment,commentList); } }}
复制代码


  • 遍历每条非回复评论。

  • 非回复评论id匹配到评论的parentId,添加到该评论的children列表中。

  • 递归调用。

结果展示:

github 源码

https://github.com/jeremylai7/java-codes/tree/master/basis/src/main/java/recurve

用户头像

Jeremy Lai

关注

还未添加个人签名 2018-02-12 加入

还未添加个人简介

评论

发布
暂无评论
Java递归实现评论多级回复_递归_Jeremy Lai_InfoQ写作社区