php實現(xiàn)網站留言板功能
我要實現(xiàn)的就是下圖的這種樣式,可參考下面這兩個網站的留言板,他們的實現(xiàn)原理都是一樣的
暢言留言板樣式:
網易跟帖樣式:
原理
需要在評論表添加兩個主要字段 id 和 pid ,其他字段隨意添加,比如文章id、回復時間、回復內容、回復人什么的。
其中pid就是當前已經回復過的評論的id。
從上圖可以看出,里面每一層的pid就是就是他上一層評論的id。仔細觀察下上面的布局。是不是很像PHP中的多維數(shù)組?如果你能想到,那么就簡單了。
實現(xiàn)方法
1.前臺:這個比較簡單 就是div嵌div。然后設置div的border和margin padding就行了
<div class="comment"> <div class="comment"> <div class="comment"> </div> </div> </div> <div class="comment"> </div>
2、后臺 :用到了兩次遞歸,首先用遞歸把數(shù)據(jù)庫中的結果重組下,重組之后,然后用遞歸輸出上面的那種前臺代碼即可
comment表結構和內容如下
然后直接讀出這個表中的所有評論??梢缘玫饺缦聰?shù)組
Array ( [0] => Array ( [id] => 1 [pid] => [content] => 評論1 ) [1] => Array ( [id] => 2 [pid] => [content] => 評論2 ) [2] => Array ( [id] => 3 [pid] => [content] => 評論3 ) [3] => Array ( [id] => 4 [pid] => 1 [content] => 評論4回復評論1 ) [4] => Array ( [id] => 5 [pid] => 1 [content] => 評論5回復評論1 ) [5] => Array ( [id] => 6 [pid] => 2 [content] => 評論6回復評論2 ) [6] => Array ( [id] => 7 [pid] => 4 [content] => 評論7回復評論4 ) [7] => Array ( [id] => 8 [pid] => 7 [content] => 評論8回復評論7 ) [8] => Array ( [id] => 9 [pid] => 8 [content] => 評論9回復評論8 ) [9] => Array ( [id] => 10 [pid] => 8 [content] => 評論10回復評論8 ) )
然后我們就需要把這個數(shù)組重組成上面的那種留言板形式的
其中$array就是上面讀取出來的數(shù)組,首先取出pid默認為空的,然后遞歸,在取出pid為當前評論id的數(shù)組
public static function tree($array,$child="child", $pid = null) { $temp = []; foreach ($array as $v) { if ($v['pid'] == $pid) { $v[$child] = self::tree($array,$child,$v['id']); $temp[] = $v; } } return $temp; }
重組后,可以得到下面的這個數(shù)組,可以看到,這個數(shù)組的樣式已經和前臺評論樣式很像了
Array ( [0] => Array ( [id] => 1 [pid] => [content] => 評論1 [child] => Array ( [0] => Array ( [id] => 4 [pid] => 1 [content] => 評論4回復評論1 [child] => Array ( [0] => Array ( [id] => 7 [pid] => 4 [content] => 評論7回復評論4 [child] => Array ( [0] => Array ( [id] => 8 [pid] => 7 [content] => 評論8回復評論7 [child] => Array ( [0] => Array ( [id] => 9 [pid] => 8 [content] => 評論9回復評論8 [child] => Array ( ) ) [1] => Array ( [id] => 10 [pid] => 8 [content] => 評論10回復評論8 [child] => Array ( ) ) ) ) ) ) ) ) [1] => Array ( [id] => 5 [pid] => 1 [content] => 評論5回復評論1 [child] => Array ( ) ) ) ) [1] => Array ( [id] => 2 [pid] => [content] => 評論2 [child] => Array ( [0] => Array ( [id] => 6 [pid] => 2 [content] => 評論6回復評論2 [child] => Array ( ) ) ) ) [2] => Array ( [id] => 3 [pid] => [content] => 評論3 [child] => Array ( ) ) )
得到上面的數(shù)組后 ,再用遞歸輸出即可
public static function traverseArray($array) { foreach ($array as $v) { echo "<div class='comment' style='width: 100%;margin: 10px;background: #EDEFF0;padding: 20px 10px;border: 1px solid #777;'>"; echo $v['content']; if ($v['child']) { self::traverseArray($v['child']); } echo "</div>"; } }
然后即可看到
原理就是這樣,就是重組下數(shù)組,然后遍歷輸出就行了。
以上就是php實現(xiàn)暢言留言板和網易跟帖樣式的全部過程,大家也可以嘗試進行創(chuàng)新,希望這篇文章對大家的學習有所幫助。
- PHP實現(xiàn)基本留言板功能原理與步驟詳解
- 使用PHP開發(fā)留言板功能
- PHP實現(xiàn)的簡單留言板功能示例【基于thinkPHP框架】
- 使用PHP連接數(shù)據(jù)庫實現(xiàn)留言板功能的實例講解(推薦)
- php+Memcached實現(xiàn)簡單留言板功能示例
- 簡單實現(xiàn)PHP留言板功能
- 基于thinkPHP框架實現(xiàn)留言板的方法
- PHP結合Mysql數(shù)據(jù)庫實現(xiàn)留言板功能
- php制作文本式留言板
- php簡單的留言板與回復功能具體實現(xiàn)
- php開發(fā)留言板的CRUD(增,刪,改,查)操作
- php xml留言板 xml存儲數(shù)據(jù)的簡單例子
- 來自經典的打造簡單的PHP&MYSQL留言板
- 一個簡單的PHP&MYSQL留言板源碼
- 一個可分頁的基于文本的PHP留言板源碼
- PHP+MySql實現(xiàn)一個簡單的留言板
相關文章
將博客園(cnblogs.com)數(shù)據(jù)導入到wordpress的代碼
博客園限制太多,于是決定從博客園(cnblogs)更換自己個人的博客。WORDPRESS口碑還不錯,于是決定用用看。之前發(fā)的數(shù)百篇日志需要導入過來,在網上搜了一會,發(fā)現(xiàn)沒有這個插件,無奈只能自己寫一個2013-01-01LAMP環(huán)境使用Composer安裝Laravel的方法
這篇文章主要介紹了LAMP環(huán)境使用Composer安裝Laravel的方法,簡單分析了Ubuntu服務器環(huán)境下Composer的安裝及使用Composer安裝Laravel的相關命令與使用技巧,需要的朋友可以參考下2017-03-03如何在Laravel5.8中正確地應用Repository設計模式
這篇文章主要介紹了如何在Laravel5.8中正確地應用Repository設計模式,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-11-11