php实现文章评论系统

作者:奇幻屋 时间:2024-05-13 09:53:40 

最近工作中需要完成一个评论的功能,上网查找了几个评论系统的展示样式。最后参考“多说”和“畅言”等评论系统,自己使用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实现文章评论系统

来源:https://blog.csdn.net/u014236259/article/details/59621561

标签:php,评论,系统
0
投稿

猜你喜欢

  • Python+matplotlib绘制不同大小和颜色散点图实例

    2021-12-02 08:50:32
  • jquery插件bootstrapValidator表单验证详解

    2024-04-22 22:22:05
  • Python中文件的读取和写入操作

    2023-01-08 22:05:52
  • 轻松搞定IE的CSS制作网页技巧3则

    2009-08-14 20:32:00
  • 详解 PyTorch Lightning模型部署到生产服务中

    2021-10-23 01:17:25
  • python实现监控linux性能及进程消耗性能的方法

    2021-10-20 03:27:56
  • linux下安装mysql简单的方法

    2024-01-19 21:02:46
  • Python标准库之数据库 sqlite3

    2024-01-24 01:50:51
  • asp产生不重复的随机数

    2008-06-03 13:29:00
  • Python中基本数据类型和常用语法归纳分享

    2023-09-08 21:08:01
  • python网络编程之TCP通信实例和socketserver框架使用例子

    2023-02-03 05:53:09
  • SQLServer用存储过程实现插入更新数据示例

    2024-01-27 23:48:05
  • 在python中如何建立一个自己的包

    2022-12-27 12:42:25
  • js中string转int把String类型转化成int类型

    2024-05-03 15:30:11
  • OpenCV+Imutils实现图像的旋转操作

    2021-07-25 20:39:42
  • Python中getservbyport和getservbyname函数的用法大全

    2023-04-14 09:02:38
  • 在python3.9下如何安装scrapy的方法

    2023-11-26 10:39:58
  • 在ASP中使用SQL语句之6:存储过程查询

    2007-08-11 12:44:00
  • mysql仿oracle的decode效果查询

    2024-01-12 22:04:00
  • vue 打包后的文件部署到express服务器上的方法

    2024-05-09 09:33:05
  • asp之家 网络编程 m.aspxhome.com