React实现二级评论

1. 什么是二级评论

图片来源--blackfrog的掘金文章

口语化的讲当我发布一个评论的时候就是一级评论,当我回复我发布的评论的时候就是二级评论并且将所有回复二级评论的评论也归于二级评论。

2. 二级评论功能的实现逻辑

在这里后端设计了四个接口分别是

  • 获取所有一级评论
  • 获取所有二级评论
  • 发布一级评论
  • 回复二级评论

在实现的时候首先调用接口获取一级评论,之后一级评论下面显示<回复--XX条-->点击之后触发调用二级评论的请求,当我获取发布评论输入框里面的文字,点击发布评论的时候默认的是一级评论

当我点击一级评论的时候输入框里会添加【@用户名 输入的内容】这里会进行二级评论的发布

同时还有删除评论的功能

  • 【需要注意评论删除的时候需要进行添加的判断------只能删除自己发布的评论】
javascript 复制代码
// 在react 中使用redux进行共享数据的管理
 const {
   reviewListContext,
   secondaryReviewListContext,
 } = useAppSelector((state) => ({
   reviewListContext: state.release.reviewList, // 获取一级评论
   secondaryReviewListContext: state.release.getSecondaryReviewList, // 获取二级评论
 }))
javascript 复制代码
{
 reviewListContext.map((item) => (
   <>
     <View>
       {/* 一级评论 */}
       <Row
         gutter="20"
         className={`comment-row ${isClicked && selectedReviewId === item.id ? 'clicked' : ''}`}
         onClick={() => selLevel1Review(item)}>
         <Col span="4" className="comment-avatar">
           <Image
             radius="50%"
             width="30px"
             height="30px"
             src={item.User.avatar}
           />
         </Col>
         <Col span="20" className="comment-content">
           <View>
             <View className="size-32">{item.User.username}</View>
           </View>
           <Text className="comment-text">{item.content}</Text>
         </Col>
       </Row>
       {/* 二级评论 */}
       {fetchedSecondaryReviews[item.id] && fetchedSecondaryReviews[item.id].map((reply) => (
         <View
           key={reply.id}
           className="comment-item reply-comment-item"
           style={{ margin: '0 0 20px 40px' }}>
           <Row
             gutter="20"
             onClick={() => selLevel2Review(reply)} // 假设selLevel2Review是处理二级评论的函数
             className="comment-row">
             <Col span="4" className="comment-avatar">
               <Image
                 radius="50%"
                 width="30px"
                 height="30px"
                 src={reply.User.avatar}
               />
             </Col>
             <Col span="20" className="comment-content">
               <View>
                 <View className="size-32">
                   {reply.User.username}
                 </View>
               </View>
               <Text className="comment-text">
                 {reply.content}
               </Text>
             </Col>
           </Row>
         </View>
       ))}
     </View>
   </>
 ))
}

上面的代码中就是二级评论的大概逻辑了,还有可以完善补充的地方!

相关推荐
passerby606131 分钟前
完成前端时间处理的另一块版图
前端·github·web components
掘了38 分钟前
「2025 年终总结」在所有失去的人中,我最怀念我自己
前端·后端·年终总结
崔庆才丨静觅41 分钟前
实用免费的 Short URL 短链接 API 对接说明
前端
崔庆才丨静觅1 小时前
5分钟快速搭建 AI 平台并用它赚钱!
前端
崔庆才丨静觅1 小时前
比官方便宜一半以上!Midjourney API 申请及使用
前端
Moment2 小时前
富文本编辑器在 AI 时代为什么这么受欢迎
前端·javascript·后端
崔庆才丨静觅2 小时前
刷屏全网的“nano-banana”API接入指南!0.1元/张量产高清创意图,开发者必藏
前端
剪刀石头布啊2 小时前
jwt介绍
前端
爱敲代码的小鱼2 小时前
AJAX(异步交互的技术来实现从服务端中获取数据):
前端·javascript·ajax
Cobyte2 小时前
AI全栈实战:使用 Python+LangChain+Vue3 构建一个 LLM 聊天应用
前端·后端·aigc