0

0

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

php中文网

php中文网

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

|

1420人浏览过

|

来源于php中文网

原创

Vondy
Vondy

下一代AI应用平台,汇集了一流的工具/应用程序

下载

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无限级分类实战——评论及回复功能 经常在各大论坛或新闻板块详情页面下边看到评论功能,当然不单单是直接发表评论内容那么简单,...

        相关文章

        PHP速学教程(入门到精通)
        PHP速学教程(入门到精通)

        PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

        下载

        本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

        热门AI工具

        更多
        DeepSeek
        DeepSeek

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

        豆包大模型
        豆包大模型

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

        WorkBuddy
        WorkBuddy

        腾讯云推出的AI原生桌面智能体工作台

        腾讯元宝
        腾讯元宝

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

        文心一言
        文心一言

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

        讯飞写作
        讯飞写作

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

        即梦AI
        即梦AI

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

        ChatGPT
        ChatGPT

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

        相关专题

        更多
        TypeScript类型系统进阶与大型前端项目实践
        TypeScript类型系统进阶与大型前端项目实践

        本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

        26

        2026.03.13

        Python异步编程与Asyncio高并发应用实践
        Python异步编程与Asyncio高并发应用实践

        本专题围绕 Python 异步编程模型展开,深入讲解 Asyncio 框架的核心原理与应用实践。内容包括事件循环机制、协程任务调度、异步 IO 处理以及并发任务管理策略。通过构建高并发网络请求与异步数据处理案例,帮助开发者掌握 Python 在高并发场景中的高效开发方法,并提升系统资源利用率与整体运行性能。

        46

        2026.03.12

        C# ASP.NET Core微服务架构与API网关实践
        C# ASP.NET Core微服务架构与API网关实践

        本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

        178

        2026.03.11

        Go高并发任务调度与Goroutine池化实践
        Go高并发任务调度与Goroutine池化实践

        本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

        51

        2026.03.10

        Kotlin Android模块化架构与组件化开发实践
        Kotlin Android模块化架构与组件化开发实践

        本专题围绕 Kotlin 在 Android 应用开发中的架构实践展开,重点讲解模块化设计与组件化开发的实现思路。内容包括项目模块拆分策略、公共组件封装、依赖管理优化、路由通信机制以及大型项目的工程化管理方法。通过真实项目案例分析,帮助开发者构建结构清晰、易扩展且维护成本低的 Android 应用架构体系,提升团队协作效率与项目迭代速度。

        92

        2026.03.09

        JavaScript浏览器渲染机制与前端性能优化实践
        JavaScript浏览器渲染机制与前端性能优化实践

        本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

        102

        2026.03.06

        Rust内存安全机制与所有权模型深度实践
        Rust内存安全机制与所有权模型深度实践

        本专题围绕 Rust 语言核心特性展开,深入讲解所有权机制、借用规则、生命周期管理以及智能指针等关键概念。通过系统级开发案例,分析内存安全保障原理与零成本抽象优势,并结合并发场景讲解 Send 与 Sync 特性实现机制。帮助开发者真正理解 Rust 的设计哲学,掌握在高性能与安全性并重场景中的工程实践能力。

        227

        2026.03.05

        PHP高性能API设计与Laravel服务架构实践
        PHP高性能API设计与Laravel服务架构实践

        本专题围绕 PHP 在现代 Web 后端开发中的高性能实践展开,重点讲解基于 Laravel 框架构建可扩展 API 服务的核心方法。内容涵盖路由与中间件机制、服务容器与依赖注入、接口版本管理、缓存策略设计以及队列异步处理方案。同时结合高并发场景,深入分析性能瓶颈定位与优化思路,帮助开发者构建稳定、高效、易维护的 PHP 后端服务体系。

        532

        2026.03.04

        AI安装教程大全
        AI安装教程大全

        2026最全AI工具安装教程专题:包含各版本AI绘图、AI视频、智能办公软件的本地化部署手册。全篇零基础友好,附带最新模型下载地址、一键安装脚本及常见报错修复方案。每日更新,收藏这一篇就够了,让AI安装不再报错!

        171

        2026.03.04

        热门下载

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

        精品课程

        更多
        相关推荐
        /
        热门推荐
        /
        最新课程
        Rust 教程
        Rust 教程

        共28课时 | 6.9万人学习

        【web前端】Node.js快速入门
        【web前端】Node.js快速入门

        共16课时 | 2.1万人学习

        国外Web开发全栈课程全集
        国外Web开发全栈课程全集

        共12课时 | 1万人学习

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

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