0

0

php无限级分类实战——评论及回复功能_PHP教程

php中文网

php中文网

发布时间:2016-07-13 09:53:27

|

1420人浏览过

|

来源于php中文网

原创

易标AI
易标AI

告别低效手工,迎接AI标书新时代!3分钟智能生成,行业唯一具备查重功能,自动避雷废标项

下载

php无限级分类实战——评论及回复功能

经常在各大论坛或新闻板块详情页面下边看到评论功能,当然不单单是直接发表评论内容那么简单,可以对别人的评论进行回复,别人又可以对你的回复再次评论或回复,如此反复,理论上可以说是没有休止,从技术角度分析很容易想到运用无限级分类技术存储数据,运用递归获取评论层级结构数据,运用ajax实现评论页面交互,这里用thinkphp框架做个简单的demo练练手,为了简化流程这里第三级评论不再提供回复功能,当然只要在这个基础上稍作修改就可以实现无限回复功能,主要是view层样式修改较麻烦,需花些时间。

一、效果需求分析:

在头部可以直接发布一级评论,最新发表的评论显示在最上面,如下效果图
这里写图片描述

对发表的评论可以回复,回复显示在上级评论下边,形成层级关系,如下效果图
这里写图片描述

页面操作细节:点击某个评论的回复按钮时,显示回复文本输入框,同时其他评论的回复文本输入框消失,当再次点击该回复按钮时,该文本框消失

在最后一级评论(这里设置是第三级)关闭回复功能

即时显示评论总数

二、实现思路及细节

1.数据表设计

评论表

2.controller层关键函数:

(1). 递归获取评论列表

/**
*递归获取评论列表
   */
   protected function getCommlist($parent_id = 0,&$result = array()){       
    $arr = M('comment')->where(parent_id = '.$parent_id.')->order(create_time desc)->select();   
    if(empty($arr)){
        return array();
    }
    foreach ($arr as $cm) {  
        $thisArr=&$result[];
        $cm[children] = $this->getCommlist($cm[id],$thisArr);    
        $thisArr = $cm;                                    
    }
    return $result;
   }

(2). 展示评论页面的action

public function index(){  
    $num =  M('comment')->count(); //获取评论总数
    $this->assign('num',$num);
      $data=array();
    $data=$this->getCommlist();//获取评论列表
    $this->assign(commlist,$data);
      $this->display('index');
  }

(3).评论页面ajax访问添加评论的action

/**
*添加评论
   */
   public function addComment(){            
    $data=array();
    if((isset($_POST[comment]))&&(!empty($_POST[comment]))){
        $cm = json_decode($_POST[comment],true);//通过第二个参数true,将json字符串转化为键值对数组
        $cm['create_time']=date('Y-m-d H:i:s',time());
        $newcm = M('comment');
        $id = $newcm->add($cm);

        $cm[id] = $id;
        $data = $cm;

        $num =  M('comment')->count();//统计评论总数
        $data['num']= $num;

    }else{
        $data[error] = 0;
    }


    echo json_encode($data);
   }

3.view层实现

(1). 展示页面的整体结构设计

这里写图片描述
实际效果:
这里写图片描述
页面html代码:




<script type="text/javascript" src="/Public/js/jquery-1.11.3.min.js"></script><script type="text/javascript" src="/Public/js/comment.js"></script>

<!--发表评论区begin-->
<span>{$num}条评论</span>
<textarea class="txt-commit" replyid="0"></textarea>
<span >发表评论</span>
<!--发表评论区end--><!--评论列表显示区begin--><!-- {$commentlist} -->
<span>全部评论</span>
<!--一级评论列表begin-->
    • <img alt="\" class="head-pic" src="http://blog.csdn.net/jo_andy/article/details/%7B%24data.head_pic%7D">
      <span>{$data.nickname}</span> <span>{$data.create_time}</span>

      {$data.content}

      <!--二级评论begin-->
        • <img alt="\" class="head-pic" src="http://blog.csdn.net/jo_andy/article/details/%7B%24child.head_pic%7D">
          <span>{$child.nickname}</span> <span>{$child.create_time}</span>

          {$child.content}

          <!--三级评论begin-->
            • <img alt="\" class="head-pic" src="http://blog.csdn.net/jo_andy/article/details/%7B%24grandson.head_pic%7D">
              <span>{$grandson.nickname}</span> <span>{$grandson.create_time}</span>

              {$grandson.content}

          •  
          •  
          <!--三级评论end-->
      •  
      •  
      <!--二级评论end-->
  •  
  •  
<!--一级评论列表end-->
<!--评论列表显示区end-->

(2). 单个评论信息div结构代码

<img alt="\" class="head-pic" src="http://blog.csdn.net/jo_andy/article/details/%7B%24data.head_pic%7D">
<span>{$data.nickname}</span> <span>{$data.create_time}</span>

{$data.content}

对应的效果图:
这里写图片描述

对应的css代码:

.head-pic{
    width:40px;
    height:40px;    
}

.cm{
    position:relative;
    top:0px;
    left:40px;
    top:-40px;
    width:600px;
}

.cm-header{
    padding-left:5px;
}

.cm-content{
    padding-left:5px;
}

.cm-footer{
    padding-bottom:15px;
    text-align:right;
    border-bottom: 1px dotted #CCC;
}

.comment-reply{
    text-decoration:none;
    color:gray;
    font-size: 14px;
}

4. JS代码

(1). 提交评论:提交评论的a标签按钮引用了样式comment-submit,在其点击事件中进行ajax操作

$('body').delegate('.comment-submit','click',function(){   
        var content = $.trim($(this).parent().prev().children(textarea).val());//根据布局结构获取当前评论内容
        $(this).parent().prev().children(textarea).val();//获取完内容后清空输入框
        if(==content){
            alert(评论内容不能为空!);     
        }else{
            var cmdata = new Object();
            cmdata.parent_id = $(this).attr(parent_id);//上级评论id
            cmdata.content = content;
            cmdata.nickname = 游客;//测试用数据
            cmdata.head_pic = /Public/images/default.jpg;//测试用数据              
            var replyswitch = $(this).attr(replyswitch);//获取回复开关锁属性
            $.ajax({
                type:POST,
                url:/index.php/home/index/addComment,
                data:{
                    comment:JSON.stringify(cmdata)              
                },
                dataType:json,            
                success:function(data){
                    if(typeof(data.error)==undefined){
                        $(.comment-reply).next().remove();//删除已存在的所有回复div    
                        //更新评论总数                        
                        $(.comment-num).children(span).html(data.num+条评论);
                        //显示新增评论
                        var newli = ;                     
                        if(cmdata.parent_id == 0){
                         //发表的是一级评论时,添加到一级ul列表中                      
                         newli = 
  • <img alt="\" class="head-pic" src="http://blog.csdn.net/jo_andy/article/details/+data.head_pic+">
    <span>+data.nickname+</span><span>+data.create_time+</span>

    +data.content+

    • ; $(.comment-ul).prepend(newli); }else{ //否则添加到对应的孩子ul列表中 if('off'==replyswitch){//检验出回复关闭锁存在,即三级评论不再提供回复功能 newli =
      • <img alt="\" class="head-pic" src="http://blog.csdn.net/jo_andy/article/details/+data.head_pic+">
        <span>+data.nickname+</span><span>+data.create_time+</span>

        +data.content+

        • ; }else{//二级评论的回复按钮要添加回复关闭锁属性 newli =
          • <img alt="\" class="head-pic" src="http://blog.csdn.net/jo_andy/article/details/+data.head_pic+">
            <span>+data.nickname+</span><span>+data.create_time+</span>

            +data.content+

            • ; } $(li[comment_id='+data.parent_id+']).children(ul).prepend(newli); } }else{ //有错误信息 alert(data.error); } } }); } });

              (2).回复评论:回复评论的a标签按钮引用了样式comment-reply,在其点击事件中进行显示或隐藏评论输入框的操作

              //点击回复按钮显示或隐藏回复输入框
                  $(body).delegate(.comment-reply,click,function(){
                      if($(this).next().length>0){//判断出回复div已经存在,去除掉
                          $(this).next().remove();
                       }else{//添加回复div
                          $(.comment-reply).next().remove();//删除已存在的所有回复div    
                          //添加当前回复div
                          var parent_id = $(this).attr(comment_id);//要回复的评论id
              
                          var divhtml = ;
                          if('off'==$(this).attr(replyswitch)){//二级评论回复后三级评论不再提供回复功能,将关闭属性附加到提交回复按钮
                              divhtml = 
              <textarea class="txt-reply" replyid="2" style="width: 100%; height: 60px;"></textarea>
              提交回复
              ; }else{ divhtml =
              <textarea class="txt-reply" replyid="2" style="width: 100%; height: 60px;"></textarea>
              提交回复
              ; } $(this).after(divhtml); } });

               

               

        www.bkjia.comtruehttp://www.bkjia.com/PHPjc/1000537.htmlTechArticlephp无限级分类实战——评论及回复功能 经常在各大论坛或新闻板块详情页面下边看到评论功能,当然不单单是直接发表评论内容那么简单,...

        热门AI工具

        更多
        DeepSeek
        DeepSeek

        幻方量化公司旗下的开源大模型平台

        豆包大模型
        豆包大模型

        字节跳动自主研发的一系列大型语言模型

        通义千问
        通义千问

        阿里巴巴推出的全能AI助手

        腾讯元宝
        腾讯元宝

        腾讯混元平台推出的AI助手

        文心一言
        文心一言

        文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

        讯飞写作
        讯飞写作

        基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

        即梦AI
        即梦AI

        一站式AI创作平台,免费AI图片和视频生成。

        ChatGPT
        ChatGPT

        最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

        相关专题

        更多
        pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
        pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

        本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

        616

        2026.02.13

        微博网页版主页入口与登录指南_官方网页端快速访问方法
        微博网页版主页入口与登录指南_官方网页端快速访问方法

        本专题系统整理微博网页版官方入口及网页端登录方式,涵盖首页直达地址、账号登录流程与常见访问问题说明,帮助用户快速找到微博官网主页,实现便捷、安全的网页端登录与内容浏览体验。

        194

        2026.02.13

        Flutter跨平台开发与状态管理实战
        Flutter跨平台开发与状态管理实战

        本专题围绕Flutter框架展开,系统讲解跨平台UI构建原理与状态管理方案。内容涵盖Widget生命周期、路由管理、Provider与Bloc状态管理模式、网络请求封装及性能优化技巧。通过实战项目演示,帮助开发者构建流畅、可维护的跨平台移动应用。

        91

        2026.02.13

        TypeScript工程化开发与Vite构建优化实践
        TypeScript工程化开发与Vite构建优化实践

        本专题面向前端开发者,深入讲解 TypeScript 类型系统与大型项目结构设计方法,并结合 Vite 构建工具优化前端工程化流程。内容包括模块化设计、类型声明管理、代码分割、热更新原理以及构建性能调优。通过完整项目示例,帮助开发者提升代码可维护性与开发效率。

        20

        2026.02.13

        Redis高可用架构与分布式缓存实战
        Redis高可用架构与分布式缓存实战

        本专题围绕 Redis 在高并发系统中的应用展开,系统讲解主从复制、哨兵机制、Cluster 集群模式及数据分片原理。内容涵盖缓存穿透与雪崩解决方案、分布式锁实现、热点数据优化及持久化策略。通过真实业务场景演示,帮助开发者构建高可用、可扩展的分布式缓存系统。

        54

        2026.02.13

        c语言 数据类型
        c语言 数据类型

        本专题整合了c语言数据类型相关内容,阅读专题下面的文章了解更多详细内容。

        29

        2026.02.12

        雨课堂网页版登录入口与使用指南_官方在线教学平台访问方法
        雨课堂网页版登录入口与使用指南_官方在线教学平台访问方法

        本专题系统整理雨课堂网页版官方入口及在线登录方式,涵盖账号登录流程、官方直连入口及平台访问方法说明,帮助师生用户快速进入雨课堂在线教学平台,实现便捷、高效的课程学习与教学管理体验。

        15

        2026.02.12

        豆包AI网页版入口与智能创作指南_官方在线写作与图片生成使用方法
        豆包AI网页版入口与智能创作指南_官方在线写作与图片生成使用方法

        本专题汇总豆包AI官方网页版入口及在线使用方式,涵盖智能写作工具、图片生成体验入口和官网登录方法,帮助用户快速直达豆包AI平台,高效完成文本创作与AI生图任务,实现便捷智能创作体验。

        598

        2026.02.12

        PostgreSQL性能优化与索引调优实战
        PostgreSQL性能优化与索引调优实战

        本专题面向后端开发与数据库工程师,深入讲解 PostgreSQL 查询优化原理与索引机制。内容包括执行计划分析、常见索引类型对比、慢查询优化策略、事务隔离级别以及高并发场景下的性能调优技巧。通过实战案例解析,帮助开发者提升数据库响应速度与系统稳定性。

        56

        2026.02.12

        热门下载

        更多
        网站特效
        /
        网站源码
        /
        网站素材
        /
        前端模板

        精品课程

        更多
        相关推荐
        /
        热门推荐
        /
        最新课程
        Node.js 教程
        Node.js 教程

        共57课时 | 11.6万人学习

        CSS3 教程
        CSS3 教程

        共18课时 | 5.8万人学习

        Rust 教程
        Rust 教程

        共28课时 | 6万人学习

        关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
        php中文网:公益在线php培训,帮助PHP学习者快速成长!
        关注服务号 技术交流群
        PHP中文网订阅号
        每天精选资源文章推送

        Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号