论坛实现思路方法较为复杂,只要把它分析下,问题就迎刃而解了,先看看论坛实现,有人发贴,然后有人跟贴,这个关系形成了种父子关联关系,般写个实用论坛,只要解决了这个子父关系,论坛即已成形.
来看看完成论坛思路方法,首先得用数据库来记载这种子父关系,般思路方法是用无重复 id 号来完成,记载父贴 id 号字段般用 "parentid" 来记载,子贴时记载父贴 id 号,而父贴 parentid 则率为 0,看看数据库记载形式:
父1:id:1 | parentid:0
子1:id:2 | parentid:1
子子1:id:3 | parentid:2
父2:id:4 | parentid:0
子2:id:5 | parentid:4
子2:id:6 | parentid:4
......
如此数据库记载子父关系已确立,接着来分析 php 是如何来实现这种父子关系确立并加入到数据库,首先用户想发言时,他贴为个父贴,因此 php 可将 parentid 设置为 0,当有用户跟贴时,php 将该用户所跟父贴 id 号附值给 parentid,这样 php 就完成了,子父关系确立.
实现了子父关系确立和,接下来就是把这种关系显示出来,这儿就需要用到递归来实现了,看下面代码:
.....
$result=mysql_query("select * from table where parentid=0");
$num=mysql_numrows($result);
(!empty($num)) {
for ($i=0;$i<$num;$i) {
$parentid=mysql_result($result,$i,"id");
function showchild($parentid) {
//加入 ul 控制层进
$result=mysql_query("select * from table where parentid=$parentid");
$numb=mysql_numrows($result);
(!empty($numb)) {
for ($i=0;$i<$numb;$i) {
....
$parentid=mysql_result($result,$i,"id");
....
showchild($parentid);
}
....
....
}
....
....
}
showchild($parentid);
....
....
}
....
....
}
上面这段代码就是利用递归来实现论坛思路方法,当然这个论坛是极其原始,在区别部分加上功能代码,就能够使这个论坛逐渐强大起来,有兴趣读者不妨自己动手试试.
最新评论