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 相关文章推荐
php SQL防注入代码集合
Apr 25 PHP
学习php笔记 字符串处理
Oct 19 PHP
提高define性能的php扩展hidef的安装和使用
Jun 14 PHP
php使用array_rand()函数从数组中随机选择一个或多个元素
Apr 28 PHP
ThinkPHP采用GET方式获取中文参数查询无结果的解决方法
Jun 26 PHP
浅析php适配器模式(Adapter)
Nov 25 PHP
php中的动态调用实例分析
Jan 07 PHP
php基于curl扩展制作跨平台的restfule 接口
May 11 PHP
PHP使用http_build_query()构造URL字符串的方法
Apr 02 PHP
CodeIgniter集成smarty的方法详解
May 26 PHP
PHP批量获取网页中所有固定种子链接的方法
Nov 18 PHP
PHP设计模式之工厂模式定义与用法详解
Apr 03 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
第一节--面向对象编程
2006/11/16 PHP
paypal即时到账php实现代码
2010/11/28 PHP
PHP 使用header函数设置HTTP头的示例解析 表头
2013/06/17 PHP
AES加解密在php接口请求过程中的应用示例
2016/10/26 PHP
thinkPHP5.1框架使用SemanticUI实现分页功能示例
2019/08/03 PHP
超级退弹代码
2008/07/07 Javascript
JS判断页面加载状态以及添加遮罩和缓冲动画的代码
2012/10/11 Javascript
jquery如何通过name名称获取当前name的value值
2013/12/20 Javascript
Chrome下ifame父窗口调用子窗口的问题示例探讨
2014/03/17 Javascript
extjs 如何给column 加上提示
2014/07/29 Javascript
node.js中的path.resolve方法使用说明
2014/12/08 Javascript
javascript实现链接单选效果的方法
2015/05/13 Javascript
跟我学习javascript的for循环和for...in循环
2015/11/18 Javascript
JS实现的仿淘宝交易倒计时效果
2015/11/27 Javascript
详解JavaScript正则表达式之RegExp对象
2015/12/13 Javascript
jQuery EasyUI学习教程之datagrid点击列表头排序
2016/07/09 Javascript
BootstrapTable+KnockoutJS自定义T4模板快速生成增删改查页面
2016/08/01 Javascript
Angularjs在初始化未完毕时出现闪烁问题的解决方法分析
2016/08/05 Javascript
vue2 自定义动态组件所遇到的问题
2017/06/08 Javascript
在 Angular中 使用 Lodash 的方法
2018/02/11 Javascript
详解vue2.0+vue-video-player实现hls播放全过程
2018/03/02 Javascript
vue实现动态添加数据滚动条自动滚动到底部的示例代码
2018/07/06 Javascript
element-ui中select组件绑定值改变,触发change事件方法
2018/08/24 Javascript
Python实例分享:快速查找出被挂马的文件
2014/06/08 Python
pymongo为mongodb数据库添加索引的方法
2015/05/11 Python
举例讲解Python编程中对线程锁的使用
2016/07/12 Python
Django中数据库的数据关系:一对一,一对多,多对多
2018/10/21 Python
获取Pytorch中间某一层权重或者特征的例子
2019/08/17 Python
Django如何使用redis作为缓存
2020/05/21 Python
Selenium之模拟登录铁路12306的示例代码
2020/07/31 Python
python更新数据库中某个字段的数据(方法详解)
2020/11/18 Python
Urban Decay官方网站:美国化妆品品牌
2020/06/04 全球购物
最新远光软件笔试题面试题内容
2013/11/08 面试题
党员公开承诺书
2014/03/25 职场文书
十佳少年事迹材料
2014/12/25 职场文书
JavaWeb Servlet开发注册页面实例
2022/04/11 Java/Android