php无限极分类以及递归(thinkphp)

php无限极分类:

无限极分类重点在于表的设计:

1在model中:

class CatModel extends Model{
    protected $cat = array();
    public function __construct(){
        parent::__construct();
        $this->cats = $this->select();
    }
public function getTree($parent_id=0,$lev=0){
        $tree = array();
        foreach($this->cats as $c){
            if ($c[‘parent_id‘] == $parent_id) {
                $c[‘lev‘] = $lev;
                $tree[] = $c;
                //再查出下层的目录拼接到一起去
                $tree = array_merge($tree,$this->getTree($c[‘cat_id‘] , $lev+1));
            }
        }
        return $tree;
    }
}

2在controller中:

class GoodsController extends Controller{
public function catelist(){
        $catModel = D(‘Cat‘);
        $catlist = $catModel->getTree();
        //print_r($catlist);
        $this->assign(‘list‘,$catlist);
        $this->display();
    }
}

3在view中:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
 <head>
  <title>管理中心 - 商品分类 </title>
  <meta name="robots" content="noindex, nofollow" />
  <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
  <link href="__PUBLIC__/Admin/styles/general.css" rel="stylesheet" type="text/css" />
  <link href="__PUBLIC__/Admin/styles/main.css" rel="stylesheet" type="text/css" />
 </head>
 <body>
  <h1> <span class="action-span"><a href="cateadd.html">添加分类</a></span> <span class="action-span1"><a href="#">管理中心</a> </span><span id="search_id" class="action-span1"> - 商品分类 </span>
   <div style="clear:both"></div> </h1>
  <form method="post" action="" name="listForm">
   <div class="list-div" id="listDiv">
    <table width="100%" cellspacing="1" cellpadding="2" id="list-table">
     <tbody>
      <tr>
       <th>分类名称</th>
       <th>商品数量</th>
       <th>数量单位</th>
       <th>导航栏</th>
       <th>是否显示</th>
       <th>价格分级</th>
       <th>排序</th>
       <th>操作</th>
      </tr> 

      <foreach name=‘catlist‘ item=‘cal‘>
      <tr align="center" class="0" id="tr_2">
       <td align="left" class="first-cell" style="padding-left="1""> <img src="__PUBLIC__/Admin/images/menu_minus.gif" id="icon_0_1" width="9" height="9" border="0" style="margin-left:{$cal[‘lev‘]*2}em" /> <span><a href="#">{$cal[‘cat_name‘]}</a></span> </td>
       <td width="10%">0</td>
       <td width="10%"><span>    </span></td>
       <td width="10%"><img src="__PUBLIC__/Admin/images/no.gif" /></td>
       <td width="10%"><img src="__PUBLIC__/Admin/images/yes.gif" /></td>
       <td><span>0</span></td>
       <td width="10%" align="right"><span>50</span></td>
       <td width="24%" align="center"><a href="{:U(‘admin/cat/catedit‘,array(‘cat_id‘=>$cal[‘cat_id‘]))}">编辑</a> | <a href="{:U(‘admin/cat/catdel‘,array(‘cat_id‘=>$cal[‘cat_id‘]))}" title="移除">移除</a> </td>
      </tr>
     </foreach>

     </tbody>
    </table>
   </div>
  </form>
 <include file=‘./Index:footer‘ />
 </body>
</html>

效果如下:

时间: 2024-10-12 20:19:12

php无限极分类以及递归(thinkphp)的相关文章

无限极分类不用递归生成多维数组(树)的方法

最近在项目中碰到的一个实际问题:后台商品分类用的是无限极方法(如图1所示), (图1) 现在前台要根据分类遍历出三级导航(效果如图2所示), (图2) 需要把查询出来的数据处理成多维数组,方便前台用多个foreach嵌套遍历. 网上多方搜集资料.经过验证成功后,记录解决方案如下: 1.从数据库查询出所有数据(项目用的ThinkPHP框架): 2.对数据进行初步处理,使二维数组的"键"与三维数组的id相等,将数据存入新数组$tmp: 1 $info = D('classify')->

无限极分类中递归查找一个树结构

问题:设计公司的员工表,员工有不同级别,要求可通过一个员工查到其下属的所有员工,也可查到其所属的上级. 解决:递归实现无限分类思想,每一个员工存入其所属的上级的id作为自己的pid,另外存入path,path包含自身id,方便显示路径. 递归的注意点: 1.一定有一个判断条件,否则递归就死循环了 2.每次的递归结果要保存起来,变量自增的实现三种方式: function(&$bar):通过引用地址 global :通过设置为全局变量 static :设置为静态变量 header( "Con

PHP无限极分类

概述 ??在实际工作中,经常要用到无限极分类.如导航表等等.到网上一搜php无限极分类,很多,但好多都是一个,并且,写的很乱,代码很多,那些都不靠谱,还是自己捣鼓捣鼓无限极分类了.下面介绍两种无限极分类:递归,使用引用 数据准备 //初始化原始数据(id=>编号,name=>显示名称,pid=>父级目录id,sort=>排序顺序) $data[1] = array('id'=>'1','name'=>'一级目录A','pid'=>'0','sort'=>'1

php递归无限极分类

递归无限级分类有几种形式,我这里只举例比较常用的三种: 第一种:返回有排序的数组: <?php $data = array( 1 => array( 'id' => 1, 'pid' => 0, 'user_name' => 'one', ), 2 => array( 'id' => 2, 'pid' => 1, 'user_name' => 'two', ), 3 => array( 'id' => 3, 'pid' => 1, '

递归与无限极分类

在函数内部调用本身,且在调用时要做判断. 例:输出1~9 function deeploop(&$i=1){   //引用传值,防止递归时从1开始 echo  $i; $i++; if($i < 10){             //条件判断,防止无限递归 deeploop($i); } } 2.无限极分类原理:每次分类都需要记录它的父级id,如果是顶级,则父级id为0,通过父级id,一层一层往下查. 首先从数据库中取出结果集,把结果集中的pid与顶级的pid开始,然后确定顶级父级.依次往下

递归的一些应用(二)无限极分类

用递归的方法实现无限极分类 通常我在写项目的时候,在写一些例如商城分类的时候会实现对应分类的上级分类,或者其它项目部门管理的上级部门的时候一般就会用到无限极分类来进行分类 第一步:首先在数据表设计的时候,如果要实现无限极分类,一般我会在数据表多添加一个字段pid,下面我通过一张新建的数据表来说明一下, (1)建表: -- ---------------------------- -- Table structure for pid -- ----------------------------

PHP无限极分类的实现(不使用递归)

无限极分类在开发中经常使用,例如:部门结构.文章分类.无限极分类的难点在于“输出”和“查询”,例如 将文章分类输出为<ul>列表形式: 查找分类A下面所有分类包含的文章. 1.实现原理 在<无限级分类实现思路>一文中介绍了几种常见的实现方法,各有利弊.其中“改进前序遍历树”数据结构,便于输出和查询,但是在移动分类和常规理解上有些复杂. 2.数据结构 id fid title 1 0 中国 2 1 江苏 3 1 安徽 4 8 江阴 5 3 芜湖 6 3 合肥 7 3 蚌埠 8 2 无

用递归的方法实现无限极分类

通常我在写项目的时候,在写一些例如商城分类的时候会实现对应分类的上级分类,或者其它项目部门管理的上级部门的时候一般就会用到无限极分类来进行分类 第一步:首先在数据表设计的时候,如果要实现无限极分类,一般我会在数据表多添加一个字段pid,下面我通过一张新建的数据表来说明一下, (1)建表: -- ---------------------------- -- Table structure for pid -- ---------------------------- DROP TABLE IF

[thinkphp] 无限极分类

<?php /* * 无限极分类 类 */ header("Content-Type: text/html; charset=UTF-8"); Class Category { //组合一维数组 Static Public function unlimitedForLevel ($cate, $html = '--', $pid = 0, $level = 0) { $arr = array(); foreach ($cate as $k => $v) { if ($v['