• 软件测试技术
  • 软件测试博客
  • 软件测试视频
  • 开源软件测试技术
  • 软件测试论坛
  • 软件测试沙龙
  • 软件测试资料下载
  • 软件测试杂志
  • 软件测试人才招聘
    暂时没有公告

字号: | 推荐给好友 上一篇 | 下一篇

php+mysql实现无限级分类 | 树型显示分类关系

发布: 2007-7-01 15:06 | 作者: admin | 来源: | 查看: 75次 | 进入软件测试论坛讨论

领测软件测试网

    无限级分类,主要是通过储存上级分类的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台灯

延伸阅读

文章来源于领测软件测试网 https://www.ltesting.net/


关于领测软件测试网 | 领测软件测试网合作伙伴 | 广告服务 | 投稿指南 | 联系我们 | 网站地图 | 友情链接
版权所有(C) 2003-2010 TestAge(领测软件测试网)|领测国际科技(北京)有限公司|软件测试工程师培训网 All Rights Reserved
北京市海淀区中关村南大街9号北京理工科技大厦1402室 京ICP备10010545号-5
技术支持和业务联系:info@testage.com.cn 电话:010-51297073

软件测试 | 领测国际ISTQBISTQB官网TMMiTMMi认证国际软件测试工程师认证领测软件测试网