Comment implémenter la fonction de réponse aux commentaires en PHP : 1. Concevoir le tableau de données ; 2. Obtenir la liste des commentaires par récursion ; 3. Afficher l'action de la page de commentaires ; 4. Afficher la conception globale de la page ; . Créez une structure d'information de commentaire unique Code ; 6. Définissez le style du bouton d'étiquette pour répondre aux commentaires.
L'environnement d'exploitation de cet article : système Windows 7, version PHP 7.1, ordinateur DELL G3
Comment implémenter la fonction de réponse aux commentaires en php ?
Classification illimitée php pour réaliser la fonction de commentaire et de réponse
Vous voyez souvent la fonction de commentaire sous la page de détails des principaux forums ou sections d'actualités. Bien sûr, ce n'est pas aussi simple que de publier directement le contenu du commentaire, vous pouvez également répondre aux commentaires d'autres personnes, d'autres peuvent commenter ou répondre à nouveau à votre réponse, et ainsi de suite, théoriquement, cela peut être considéré comme infini. D'un point de vue technique, il est facile d'envisager d'utiliser une technologie de classification infinie pour stocker des données. , en utilisant la récursion pour obtenir les données de structure hiérarchique des commentaires et en utilisant ajax pour implémenter l'interaction avec la page de commentaires, voici une démonstration simple utilisant le framework thinkphp pour s'entraîner. Afin de simplifier le processus, les commentaires de troisième niveau commencent à cesser de répondre. , tant que quelques modifications sont apportées sur cette base, la fonction de réponse infinie peut être réalisée, principalement la modification du style de la couche de vue. C'est plus gênant et prend un certain temps.
1. Analyse de la demande d'effet :
1 Vous pouvez publier des commentaires de premier niveau directement dans l'en-tête, et les derniers commentaires sont affichés en haut, comme le montrent les rendus suivants
2. peut répondre aux commentaires publiés, les réponses sont affichées sous les commentaires supérieurs, formant une relation hiérarchique, comme le montre le rendu suivant
3. Détails du fonctionnement de la page : Lorsque vous cliquez sur le bouton de réponse d'un commentaire, le texte de réponse est saisi. La zone de texte s'affiche et les zones de saisie de texte de réponse des autres commentaires disparaissent Lorsque vous cliquez à nouveau sur le bouton de réponse, la zone de texte disparaît
4 Désactivez la fonction de réponse au dernier niveau de commentaire (ici défini sur le troisième niveau).
5. Afficher le nombre total de commentaires en temps réel
2. Idées et détails de mise en œuvre
2. Clé de couche de contrôleur fonction : (1). Obtenez récursivement la liste des commentaires
/** *递归获取评论列表 */ 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). Afficher l'action de la page de commentaires
public function index(){ $num = M('comment')->count(); //获取评论总数 $this->assign('num',$num); $data=array(); $data=$this->getCommlist();//获取评论列表 $this->assign("commlist",$data); $this->display('index'); }
(3). mise en œuvre
(1). Afficher la conception structurelle globale de la page
Effet réel : Code html de la page :/** *添加评论 */ 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); }
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html lang="en"> <head> <meta http-equiv="Content-Type" content="text/html;charset=UTF-8"> <title>php无限级分类实战————评论及回复功能</title> <link rel="stylesheet" type="text/css" href="/Public/css/comment.css" rel="external nofollow" > <script type="text/javascript" src="/Public/js/jquery-1.11.3.min.js" ></script> <script type="text/javascript" src="/Public/js/comment.js" ></script> </head> <body> <p class="comment-filed"> <!--发表评论区begin--> <p> <p class="comment-num"> <span>{$num}条评论</span> </p> <p> <p> <textarea class="txt-commit" replyid="0"></textarea> </p> <p class="p-txt-submit"> <a class="comment-submit" parent_id="0" style="" href="javascript:void(0);" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" ><span style=''>发表评论</span></a> </p> </p> </p> <!--发表评论区end--> <!--评论列表显示区begin--> <!-- {$commentlist} --> <p class="comment-filed-list" > <p><span>全部评论</span></p> <p class="comment-list" > <!--一级评论列表begin--> <ul class="comment-ul"> <volist name="commlist" id="data"> <li comment_id="{$data.id}"> <p > <p> <img class="head-pic" src="{$data.head_pic}" alt=""> </p> <p class="cm"> <p class="cm-header"> <span>{$data.nickname}</span> <span>{$data.create_time}</span> </p> <p class="cm-content"> <p> {$data.content} </p> </p> <p class="cm-footer"> <a class="comment-reply" comment_id="{$data.id}" href="javascript:void(0);" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" >回复</a> </p> </p> </p> <!--二级评论begin--> <ul class="children"> <volist name="data.children" id="child" > <li comment_id="{$child.id}"> <p > <p> <img class="head-pic" src="{$child.head_pic}" alt=""> </p> <p class="children-cm"> <p class="cm-header"> <span>{$child.nickname}</span> <span>{$child.create_time}</span> </p> <p class="cm-content"> <p> {$child.content} </p> </p> <p class="cm-footer"> <a class="comment-reply" replyswitch="off" comment_id="{$child.id}" href="javascript:void(0);" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" >回复</a> </p> </p> </p> <!--三级评论begin--> <ul class="children"> <volist name="child.children" id="grandson" > <li comment_id="{$grandson.id}"> <p > <p> <img class="head-pic" src="{$grandson.head_pic}" alt=""> </p> <p class="children-cm"> <p class="cm-header"> <span>{$grandson.nickname}</span> <span>{$grandson.create_time}</span> </p> <p class="cm-content"> <p> {$grandson.content} </p> </p> <p class="cm-footer"> <!-- <a class="comment-reply" comment_id="1" href="javascript:void(0);" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" >回复</a> --> </p> </p> </p> </li> </volist> </ul> <!--三级评论end--> </li> </volist> </ul> <!--二级评论end--> </li> </volist> </ul> <!--一级评论列表end--> </p> </p> <!--评论列表显示区end--> </p> </body> </html>
(1) : le bouton d'étiquette qui soumet des commentaires fait référence au style comment-submit et effectue des opérations ajax. dans son événement de clic
<p > <p> <img class="head-pic" src="{$data.head_pic}" alt=""> </p> <p class="cm"> <p class="cm-header"> <span>{$data.nickname}</span> <span>{$data.create_time}</span> </p> <p class="cm-content"> <p> {$data.content} </p> </p> <p class="cm-footer"> <a class="comment-reply" comment_id="{$data.id}" href="javascript:void(0);" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" >回复</a> </p> </p> </p>
(2). Répondre aux commentaires : Le bouton d'étiquette qui répond aux commentaires fait référence au style commentaire-réponse, effectue l'opération d'affichage ou de masquage de la zone de saisie du commentaire dans son événement de clic Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!.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;
}