coolswood
@coolswood
https://coolswood.github.io

Как вывести на страницу вложенные комментарии на React?

Стоит задача выводить комментарии на страницу. С сервера приходит следующий JSON:
"comments": [
    {
        "id": 92241,
        "text": "Поздравляю и желанию дальнейшего процветания. Успехов и всего самого наилучшего. Ваша новость еще раз свидетельство того, что все под силу изменить, если нас много и мы едины.",
        "edit_link": "http://localhost:8006/admin/comments/comment/92241/change/",
        "level": 0,
        "allow_reply": true,
        "replies": []
    },
    {
        "id": 92241,
        "text": "Поздравляю и желанию дальнейшего процветания. Успехов и всего самого наилучшего. Ваша новость еще раз свидетельство того, что все под силу изменить, если нас много и мы едины.",
        "edit_link": "http://localhost:8006/admin/comments/comment/92241/change/",
        "level": 0,
        "allow_reply": true,
        "replies": [
            {
                "id": 92241,
                "text": "Поздравляю и желанию дальнейшего процветания. Успехов и всего самого наилучшего. Ваша новость еще раз свидетельство того, что все под силу изменить, если нас много и мы едины.",
                "edit_link": "http://localhost:8006/admin/comments/comment/92241/change/",
                "level": 0,
                "allow_reply": true,
                "replies": []
            },
            {
                "id": 92241,
                "text": "Поздравляю и желанию дальнейшего процветания. Успехов и всего самого наилучшего. Ваша новость еще раз свидетельство того, что все под силу изменить, если нас много и мы едины.",
                "edit_link": "http://localhost:8006/admin/comments/comment/92241/change/",
                "level": 0,
                "allow_reply": true,
                "replies": [
                    {
                        "id": 92241,
                        "text": "Поздравляю и желанию дальнейшего процветания. Успехов и всего самого наилучшего. Ваша новость еще раз свидетельство того, что все под силу изменить, если нас много и мы едины.",
                        "edit_link": "http://localhost:8006/admin/comments/comment/92241/change/",
                        "level": 0,
                        "allow_reply": true,
                        "replies": []
                    }
                ]
            }
        ]
    }
]

Я понимаю, что в компоненте нужно запустить рекурсию, но до конца не понимаю как прописать условие чтобы не уйти в бесконечный цикл.
Сейчас делаю так
В родителе:
{this.props.comments.map((item, id) => {
                    return (
                        <div className="talk-branch">
                            <Comment {...item} />
                        </div>
                    )
                })}

В компоненте:
var Comment = class Comment extends React.Component {

    render() {
        const { fullname, date, text, replies } = this.props;
        return (<div className="talk-branch__item">
            <div className="talk-branch-main">
                <div className="talk-branch__avatar">
                    <img src="https://www.fursk.ru/static/img/talk/woman_avatar.png" alt="avatar"/>
                </div>
                <div className="talk-branch__body">
                    <div className="talk-branch__body-author" itemType="http://schema.org/Person" itemProp="author">
                        <span className="talk-branch__body-name" itemProp="name">{fullname}</span>
                    </div>
                    <div className="talk-branch__date">
                        <time itemProp="datePublished" datetime={date}>
                            {date}
                        </time>
                    </div>
                    <div className="talk-branch__text" itemProp="reviewBody">
                        {text}
                    </div>
                    <div className="talk-branch__reply">
                        <div onClick={this.toggleForm}>Ответить</div>
                    </div>
                </div>
            </div>
           {replies && replies.length !== 0 ?
                replies.map((item, id) => {
                    return <Comment {...item} />
                })
            :
            false}
        </div>)
    }
}
export default Comment;
  • Вопрос задан
  • 1589 просмотров
Решения вопроса 1
Vlad_IT
@Vlad_IT Куратор тега JavaScript
Front-end разработчик
Вы в компоненте при вызове самого себя не передаете комментарий. Еще бы хорошо сделать так, чтобы вызов Comment происходил только при наличии комментариев. Да и в комменте вы один раз вызываете Comment, а не список комментов.
Я бы сделал так. Создал компонент CommentList, в нем сделал вызов текущих комментов Comment в цикле. И в компоненте Comment сделал проверку на наличие комментов, если они есть, вызывал бы CommentList (передавая ему список комментов), тот в свое время опять циклом пройдет по комментам и вызовет компонент Comment, и.т.д.
Ответ написан
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы