php实现文章评论系统


Posted in PHP onFebruary 18, 2019

最近工作中需要完成一个评论的功能,上网查找了几个评论系统的展示样式。最后参考“多说”和“畅言”等评论系统,自己使用PHP语言实现了一个简单的评论系统。并记录了两种方式(递归方式和非递归方式)的实现过程,以及分析两种方式的优缺点,但前端如何实现就没有展现了。

首先设计数据库如下:

create table `comments`(
 `id` bigint unsigned not null AUTO_INCREMENT,
 `arc_id` bigint unsigned not null COMMENT '文章id',
 `user_id` bigint unsigned not null COMMENT '用户id',
 `comment_id` bigint unsigned not null DEFAULT '0' COMMENT '回复某个评论的id',
 `content` varchar(255) not null DEFAULT '' COMMENT '评论或回复的内容',
 `add_time` timestamp not null DEFAULT CURRENT_TIMESTAMP COMMENT '添加时间',
 PRIMARY KEY (`id`),
 KEY `arc_id` (`arc_id`)
)ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT '文章评论表';

创建测试数据如下:

php实现文章评论系统

具体实现方案如下(在ThinkPHP框架上实现):

1、递归方式

优点:实现代码简单,而且如果评论的层级固定在5个层次一下的话,建议使用该种方法,这样前端通过这种数据结果实现简单。

缺点:如果评论的层级没有固定的话,前端将无法展示评论信息了,而且如果层级太多的话,将会极大的消耗内存,更要命的是每次递归都得查询数据库,性能将大大的降低。

/**
 * @param $arc_id  文章id
 * @param int $comm_id  评论id
 * @param array $result
 * @return array
 */
function getCommlist($arc_id, $comm_id = 0, &$result = array()){  //获取评论列表
 if(empty($arc_id)){
 return array();
 }
 $_where = "arc_id = {$arc_id} AND comment_id = {$comm_id}";
 $res = M('comments')->where($_where)->order('add_time DESC')->select();
 if(empty($res)){
 return array();
 }
 foreach ($res as $cm) {
 $thisArr = &$result[];
 $cm["_child"] = getCommlist($arc_id,$cm['id'],$thisArr);
 $thisArr = $cm;
 }
 
 return $result;
}

部分数据展示如下:

php实现文章评论系统

2、非递归方式(堆栈方式实现)

优点:只查询一次数据库,性能较好。可以实现n层级的评论,前端也能很好的展示

缺点:代码稍微复杂,对于固定的层级评论,前端展示评论较为复杂。

/**
 * @param $arc_id 文章id
 * @return array
 */
public function getCommlist($arc_id){
 if(empty($arc_id)){
 return array();
 }
 $res = M('comments')->where(array('arc_id'=>$arc_id))->order('add_time ASC')->select();
 $dataList = $stack = array();
 if($res){
 foreach($res AS $k=>$v){  //先将评论的数据进行入库(即comment_id=0)
  if($v['comment_id'] == 0){
  $v['_level'] = 0;  //设置层级数
  $v['_root'] = $v['id'];  //标识评论id
  array_push($stack,$v);  //入栈
  unset($res[$k]);
  }
 }
 
 while(!empty($stack)){
  $node = array_pop($stack);  //出栈
  $dataList[] = $node;
  foreach($res as $_k=>$_v){
  if($_v['comment_id'] == $node['id']){
   $_v['_level'] = $node['_level']+1;  //设置层级数
   $_v['_root'] = $node['_root'];  //标识评论id
   array_push($stack,$_v);  //入栈
   unset($res[$_k]);
  }
  }
 }
 }
 
 return $dataList;
}

数据展示效果如下:

php实现文章评论系统

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

PHP 相关文章推荐
ip签名探针
Oct 09 PHP
php中的观察者模式
Mar 24 PHP
php class中public,private,protected的区别以及实例分析
Jun 18 PHP
PHP图片上传代码
Nov 04 PHP
PHP删除数组中空值的方法介绍
Apr 14 PHP
PHP中file_get_contents高?用法实例
Sep 24 PHP
php安装php_rar扩展实现rar文件读取和解压的方法
Nov 17 PHP
Yii2-GridView 中让关联字段带搜索和排序功能示例
Jan 21 PHP
PHP微信开发之微信录音临时转永久存储
Jan 26 PHP
php+mysql开发中的经验与常识小结
Mar 25 PHP
详细分析PHP 命名空间(namespace)
Jun 30 PHP
PHP与Web页面的交互示例详解一
Aug 04 PHP
php无限级分类实现评论及回复功能
Feb 18 #PHP
PHP-FPM 的管理和配置详解
Feb 17 #PHP
PHP get_html_translation_table()函数用法讲解
Feb 16 #PHP
PHP5.5基于mysqli连接MySQL数据库和读取数据操作实例详解
Feb 16 #PHP
PHP封装的mysqli数据库操作类示例
Feb 16 #PHP
PHP fprintf()函数用法讲解
Feb 16 #PHP
PHP explode()函数用法讲解
Feb 15 #PHP
You might like
php获取操作系统语言代码
2013/11/04 PHP
PHP+redis实现添加处理投票的方法
2015/11/14 PHP
php实现的中文分词类完整实例
2017/02/06 PHP
图片无缝滚动代码(向左/向下/向上)
2013/04/10 Javascript
js简易namespace管理器 实例代码
2013/06/21 Javascript
页面装载js及性能分析方法介绍
2014/03/21 Javascript
Javascript中的默认参数详解
2014/10/22 Javascript
JavaScript中模拟实现jsonp
2015/06/19 Javascript
浅析JavaScript函数的调用模式
2016/08/10 Javascript
js基础之DOM中元素对象的属性方法详解
2016/10/28 Javascript
ES2015 Symbol 一种绝不重复的值
2016/12/25 Javascript
async/await与promise(nodejs中的异步操作问题)
2017/03/03 NodeJs
JS实现列表页面隔行变色效果
2017/03/25 Javascript
详解nodejs微信公众号开发——5.素材管理接口
2017/04/11 NodeJs
vue登录路由验证的实现
2017/12/13 Javascript
iview同时验证多个表单问题总结
2018/09/29 Javascript
vue路由对不同界面进行传参及跳转的总结
2019/04/20 Javascript
解决vue项目刷新后,导航菜单高亮显示的位置不对问题
2019/11/01 Javascript
vue实现动态给id赋值,点击事件获取当前点击的元素的id操作
2020/11/09 Javascript
在Python中处理日期和时间的基本知识点整理汇总
2015/05/22 Python
selenium python 实现基本自动化测试的示例代码
2019/02/25 Python
树莓派使用python-librtmp实现rtmp推流h264的方法
2019/07/22 Python
Django models.py应用实现过程详解
2019/07/29 Python
深入了解Python装饰器的高级用法
2020/08/13 Python
python em算法的实现
2020/10/03 Python
使用css3和jquery实现可伸缩搜索框
2014/02/12 HTML / CSS
关于HTML5的22个初级技巧(图文教程)
2012/06/21 HTML / CSS
html5拍照功能实现代码(htm5上传文件)
2013/12/11 HTML / CSS
俄罗斯游戏商店:Buka
2020/03/01 全球购物
What's the difference between Debug and Trace class? (Debug类与Trace类有什么区别)
2013/09/10 面试题
重写子类方法时,抛出异常的书写注意事项
2015/10/17 面试题
项目专员岗位职责
2013/12/04 职场文书
个人作风建设心得体会
2014/10/22 职场文书
医生见习报告范文
2014/11/03 职场文书
2015年学生会干事工作总结
2015/04/09 职场文书
python实现会员管理系统
2022/03/18 Python