首 页 | 新 闻 | 技术中心 | 第二书店 | 《程序员》 | 《开发高手》 | 社 区 | 黄 页 | 人 才
移 动专 题SUNIBM微 软微 创精 华Donews人 邮
我的技术中心 
我的分类 我的文档
全部文章 发表文章
专栏管理 使用说明



 RSS 订阅 
最新文档列表
Windows/.NET
.NET  (rss)    
Visual C++  (rss)    
Delphi  (rss)    
Visual Basic  (rss)    
ASP  (rss)    
JavaScript  (rss)    
Java/Linux
Java  (rss)    
Perl  (rss)    
综合
其他开发语言  (rss)    
文件格式  (rss)    
企业开发
游戏开发  (rss)    
网站制作技术  (rss)    
数据库
数据库开发  (rss)    
软件工程
其他  (rss)    

积极原创作者 
zjzcl (28)
iiprogram (104)
whoopee (61)
lzmtw (32)
longrujun (79)
daisylh (21)
yjz0065 (122)
superyan (28)
cyz1980 (103)
sharpdew (1)
CSDN - 文档中心 - 其他开发语言 阅读:18   评论: 0    参与评论
标题   php+mysql实现无限级分类 | 树型显示分类关系     选择自 wxkingstar 的 Blog
关键字   php+mysql实现无限级分类 | 树型显示分类关系
出处  

    无限级分类,主要是通过储存上级分类的id以及分类路径来实现。由于数据的结构简单,所以要将分类的关系由树状显示,我只能想到用递归的方式给于实现,下面是分类数据表结构和自己写的一个树状显示函数,有什么不妥的地方希望大家能指出。

    表结构:id字段为分类标识,name字段为分类名,father_id字段为所属父分类的id,path字段为分类路径(储存该分类祖先的集合),isdir判断是否是目录(1为是,0为否)。

    显示函数:

//$count为分类等级
 sort_list($str,$fatherid,$count)
 {
  $rs = $this->sql->re_datas("select * from sort where father_id = fatherid");
  $num = $this->sql->sql_numrows();
  $i=0;
  $n = 1;
  while(isset($rs[$i]))
  {
   $name = "";
   for($n = 1 ; $n < $count ; $n++)
   {
    $name.="│    ";
   }
   if($i+1==$num)
   {
    $name.="└─".$rs[$i][name];
   }
   else
   {
    $name.="├─".$rs[$i][name];
   }
   if($rs[$i][isdir])
   {
    $str.="<span style='color:#CCCCCC'>".$name."</span>";
   }
   else
   {
    $str.=$name";
   }
   $temp = $count+1;
   $str = $this->sort_list($str,$rs[$i][id],$temp);
   $i++;
  }
  return $str;
 }


 其中$this->sql对象为sql操作类对象,re_datas()函数返回查到的数组,sql_numrows()函数返回查询到的数目
 
 调用方法:$sort_list = sort_list($sort_list,0,1);

以上为个人思想,还望大家多多指点。by 5w台灯


相关文章
对该文的评论