php實現評論回覆功能的方法:1、進行資料表設計;2、透過遞迴取得評論清單;3、展示評論頁面的action;4、展示頁面的整體結構設計;5、建立單一評論訊息p結構代碼;6、設定回覆評論的a標籤按鈕樣式。
本文操作環境:windows7系統、PHP7.1版,DELL G3電腦
php怎麼實作評論回覆功能?
php無限級分類實現評論及回覆功能
經常在各大論壇或新聞板塊詳情頁面下邊看到評論功能,當然不單單是直接發表評論內容那麼簡單,可以對別人的評論進行回复,別人又可以對你的回复再次評論或回复,如此反复,理論上可以說是沒有休止,從技術角度分析很容易想到運用無限級分類技術儲存數據,運用遞歸獲取評論層級結構數據,運用ajax實現評論頁面交互,這裡用thinkphp框架做個簡單的demo練練手,為了簡化流程這裡第三級評論開始停止回复,當然只要在這個基礎上稍作修改可實現無限回復功能,主要是view層樣式修改較麻煩,需花點時間。
一、效果需求分析:
1.在頭部可以直接發布一級評論,最新發表的評論顯示在最上面,如下效果圖
2.對發表的評論可以回复,回复顯示在上級評論下邊,形成層級關係,如下效果圖
3.頁面操作細節:點擊某個評論的回复按鈕時,顯示回复文本輸入框,同時其他評論的回复文本輸入框消失,當再次點擊該回复按鈕時,該文本框消失
# 4.在最後一級評論(這裡設定是第三級)關閉回應功能
5.即時顯示評論總數
##二、實現想法及細節
#1.資料表設計
2.controller層關鍵函數:
(1). 遞迴取得評論清單
/** *递归获取评论列表 */ 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). 展示評論頁面的action#
public function index(){ $num = M('comment')->count(); //获取评论总数 $this->assign('num',$num); $data=array(); $data=$this->getCommlist();//获取评论列表 $this->assign("commlist",$data); $this->display('index'); }(3).評論頁面ajax訪問新增評論的action
/** *添加评论 */ 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); }
#3.view層實作
實際效果:
#頁面html程式碼:<!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" 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 lazy" src="/static/imghwm/default1.png" data-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 lazy" src="/static/imghwm/default1.png" data-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 lazy" src="/static/imghwm/default1.png" data-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>
(2). 單一評論訊息p結構代碼<p >
<p>
<img class="head-pic lazy" src="/static/imghwm/default1.png" data-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>
對應的效果圖:
.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; }#################################################### #####4. JS程式碼############(1). 提交評論:提交評論的a標籤按鈕引用了樣式comment-submit,在其點擊事件中進行ajax操作# ##
$('body').delegate('.comment-submit','click',function(){ var content = $.trim($(this).parent().prev().children("textarea").val());//根据布局结构获取当前评论内容 $(this).parent().prev().children("textarea").val("");//获取完内容后清空输入框 if(""==content){ alert("评论内容不能为空!"); }else{ var cmdata = new Object(); cmdata.parent_id = $(this).attr("parent_id");//上级评论id cmdata.content = content; cmdata.nickname = "游客";//测试用数据 cmdata.head_pic = "/Public/images/default.jpg";//测试用数据 var replyswitch = $(this).attr("replyswitch");//获取回复开关锁属性 $.ajax({ type:"POST", url:"/index.php/home/index/addComment", data:{ comment:JSON.stringify(cmdata) }, dataType:"json", success:function(data){ if(typeof(data.error)=="undefined"){ $(".comment-reply").next().remove();//删除已存在的所有回复p //更新评论总数 $(".comment-num").children("span").html(data.num+"条评论"); //显示新增评论 var newli = ""; if(cmdata.parent_id == "0"){ //发表的是一级评论时,添加到一级ul列表中 newli = "<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);'>回复</a></p></p></p><ul class='children'></ul></li>"; $(".comment-ul").prepend(newli); }else{ //否则添加到对应的孩子ul列表中 if('off'==replyswitch){//检验出回复关闭锁存在,即三级评论不再提供回复功能 newli = "<li comment_id='"+data.id+"'><p ><p><img class='head-pic' src='"+data.head_pic+"' alt=''></p><p class='children-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'></p></p></p><ul class='children'></ul></li>"; }else{//二级评论的回复按钮要添加回复关闭锁属性 newli = "<li comment_id='"+data.id+"'><p ><p><img class='head-pic' src='"+data.head_pic+"' alt=''></p><p class='children-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);' replyswitch='off' >回复</a></p></p></p><ul class='children'></ul></li>"; } $("li[comment_id='"+data.parent_id+"']").children("ul").prepend(newli); } }else{ //有错误信息 alert(data.error); } } }); } });###(2).回覆評論:回覆評論的a標籤按鈕引用了樣式comment-reply,在其點擊事件中進行顯示或隱藏評論輸入框的操作###
//点击"回复"按钮显示或隐藏回复输入框 $("body").delegate(".comment-reply","click",function(){ if($(this).next().length>0){//判断出回复p已经存在,去除掉 $(this).next().remove(); }else{//添加回复p $(".comment-reply").next().remove();//删除已存在的所有回复p //添加当前回复p var parent_id = $(this).attr("comment_id");//要回复的评论id var phtml = ""; if('off'==$(this).attr("replyswitch")){//二级评论回复后三级评论不再提供回复功能,将关闭属性附加到"提交回复"按钮" phtml = "<p class='p-reply-txt' style='width:98%;padding:3px;' replyid='2'><p><textarea class='txt-reply' replyid='2' style='width: 100%; height: 60px;'></textarea></p><p style='margin-top:5px;text-align:right;'><a class='comment-submit' parent_id='"+parent_id+"' style='font-size:14px;text-decoration:none;background-color:#63B8FF;' href='javascript:void(0);' replyswitch='off' >提交回复</a></p></p>"; }else{ phtml = "<p class='p-reply-txt' style='width:98%;padding:3px;' replyid='2'><p><textarea class='txt-reply' replyid='2' style='width: 100%; height: 60px;'></textarea></p><p style='margin-top:5px;text-align:right;'><a class='comment-submit' parent_id='"+parent_id+"' style='font-size:14px;text-decoration:none;background-color:#63B8FF;' href='javascript:void(0);'>提交回复</a></p></p>"; } $(this).after(phtml); } });###推薦學習: 《###PHP影片教學###》###
以上是php怎麼實現評論回應功能的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本文比較了酸和基本數據庫模型,詳細介紹了它們的特徵和適當的用例。酸優先確定數據完整性和一致性,適合財務和電子商務應用程序,而基礎則側重於可用性和

本文討論了確保PHP文件上傳的確保,以防止諸如代碼注入之類的漏洞。它專注於文件類型驗證,安全存儲和錯誤處理以增強應用程序安全性。

本文討論了在PHP中實施API速率限制的策略,包括諸如令牌桶和漏水桶等算法,以及使用Symfony/Rate-limimiter之類的庫。它還涵蓋監視,動態調整速率限制和手

本文討論了使用password_hash和pyspasswify在PHP中使用密碼的好處。主要論點是,這些功能通過自動鹽,強大的哈希算法和SECH來增強密碼保護

本文討論了OWASP在PHP和緩解策略中的十大漏洞。關鍵問題包括注射,驗證損壞和XSS,並提供用於監視和保護PHP應用程序的推薦工具。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

SAP NetWeaver Server Adapter for Eclipse
將Eclipse與SAP NetWeaver應用伺服器整合。

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

Atom編輯器mac版下載
最受歡迎的的開源編輯器

Dreamweaver CS6
視覺化網頁開發工具

Dreamweaver Mac版
視覺化網頁開發工具