Java递归实现评论多级回复功能代码示例

作者:袖梨 2022-06-29

本篇文章小编给大家分享一下Java递归实现评论多级回复功能代码示例,小编觉得挺不错的,现在分享给大家供大家参考,有需要的小伙伴们可以来看看。

评论实体

数据库存储字段: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 children

ViewComment结构如下:

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

添加非回复评论

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

List 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 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列表中。

递归调用。

结果展示:

相关文章

精彩推荐