下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
第php实现文章评论系统最近工作中需要完成一个评论的功能,上网查找了几个评论系统的展示样式。最后参考“多说”和“畅言”等评论系统,自己使用PHP语言实现了一个简单的评论系统。并记录了两种方式(递归方式和非递归方式)的实现过程,以及分析两种方式的优缺点,但前端如何实现就没有展现了。
首先设计数据库如下:
createtable`comments`(
`id`bigintunsignednotnullAUTO_INCREMENT,
`arc_id`bigintunsignednotnullCOMMENT'文章id',
`user_id`bigintunsignednotnullCOMMENT'用户id',
`comment_id`bigintunsignednotnullDEFAULT'0'COMMENT'回复某个评论的id',
`content`varchar(255)notnullDEFAULT''COMMENT'评论或回复的内容',
`add_time`timestampnotnullDEFAULTCURRENT_TIMESTAMPCOMMENT'添加时间',
PRIMARYKEY(`id`),
KEY`arc_id`(`arc_id`)
)ENGINE=InnoDBDEFAULTCHARSET=utf8COMMENT'文章评论表';
创建测试数据如下:
具体实现方案如下(在ThinkPHP框架上实现):
1、递归方式
优点:实现代码简单,而且如果评论的层级固定在5个层次一下的话,建议使用该种方法,这样前端通过这种数据结果实现简单。
缺点:如果评论的层级没有固定的话,前端将无法展示评论信息了,而且如果层级太多的话,将会极大的消耗内存,更要命的是每次递归都得查询数据库,性能将大大的降低。
*@param$arc_id文章id
*@paramint$comm_id评论id
*@paramarray$result
*@returnarray
functiongetCommlist($arc_id,$comm_id=0,$result=array()){//获取评论列表
if(empty($arc_id)){
returnarray();
$_where="arc_id={$arc_id}ANDcomment_id={$comm_id}";
$res=M('comments')-where($_where)-order('add_timeDESC')-select();
if(empty($res)){
returnarray();
foreach($resas$cm){
$thisArr=$result[];
$cm["_child"]=getCommlist($arc_id,$cm['id'],$thisArr);
$thisArr=$cm;
return$result;
}
部分数据展示如下:
2、非递归方式(堆栈方式实现)
优点:只查询一次数据库,性能较好。可以实现n层级的评论,前端也能很好的展示
缺点:代码稍微复杂,对于固定的层级评论,前端展示评论较为复杂。
*@param$arc_id文章id
*@returnarray
publicfunctiongetCommlist($arc_id){
if(empty($arc_id)){
returnarray();
$res=M('comments')-where(array('arc_id'=$arc_id))-order('add_timeASC')-select();
$dataList=$stack=array();
if($res){
foreach($resAS$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($resas$_k=$_v){
if($_v['comment_id']==$node['id']){
$_v['_level']=$node['_level']+1;//设置层级数
$_v['_root']=$node['_root'];//标识评论id
array_push($s
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2026云南昆明市卫生健康委员会“梦想不远昆明首选”全国引才活动后备人才招聘114人考试参考试题及答案解析
- 2026陕西西咸新区人力资源服务中心就业见习人员招聘4人考试备考试题及答案解析
- 2026年宿州市新汴河景区旅游发展有限责任公司招聘就业见习人员考试参考试题及答案解析
- 2026海南水发农业旅游发展有限公司招聘6人考试参考题库及答案解析
- 2026年中国石油广西石化分公司校园招聘笔试参考题库及答案解析
- 2026贵州黔东南州三穗县第四批城镇公益性岗位招聘10人考试参考题库及答案解析
- 2026内蒙古威信保安押运服务有限责任公司竞聘纪检监督部职员1人考试备考试题及答案解析
- 2026宁夏宝丰储能正极材料厂招聘165人考试参考题库及答案解析
- 2026年中国移动贵州分公司校园招聘考试备考题库及答案解析
- 2025-2026学年荷花教案网站分享
- 2026丽水市国有资本运营有限公司公开招聘工作人员5人考试参考题库及答案解析
- 2026年亳州职业技术学院单招职业倾向性考试题库含答案详解(巩固)
- 煤矿培训纪律制度
- 2025年天津市高考历史真题卷含答案解析
- 2026国家新闻出版广电总局监管中心招聘35人易考易错模拟试题(共500题)试卷后附参考答案
- 2025年福建省高速公路集团有限公司综合管理类岗位招聘34人笔试参考题库附带答案详解(3卷)
- 2025年课件-(已瘦身)2023版马原马克思主义基本原理(2023年版)全套教学课件-新版
- 大学综合实验楼项目风险评估报告
- 科技预见与未来愿景 2049 中文版
- 2025环境工程考研水处理工程模拟卷及答案
- 【英语+答案】常州市 2025-2026 学年第一学期高三期中质量调研英语试题
评论
0/150
提交评论