A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

本篇文章给大家带来的内容是介绍php如何实现无限极分类?无限极分类的三种实现方法(代码详解)。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。
无限极分类1:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
public function judeg($id)
{
   $rs = Db::name('finance_class') -> field('parent_code') -> where('id',$id) -> select();
   $i = 1;
   foreach($rs as $k => $v){
     if($v['parent_code'] <> 0){
       $i += $this -> judeg($v['parent_code']);
      }
   }
   return $i;
}

public function cid($id,$pid)
{
    $w['parent_code'] = $id;
    $rs = Db::name('finance_class')
       -> field('id,code,name,parent_code')
       -> where($w)
       -> order('code asc')
       -> select();
    $str = '';
    foreach ($rs as $k => $v) {
        $name = $v['name'];
        $_id = $v['id'];
        $cutOff = '';
        for($i = 0; $i < $this -> judeg($_id); $i++){
          $cutOff.='-';
        }
        if($_id == $pid){
          $str.='<p>他的id='.$_id.'====他的级别'.$cutOff.$name.'</p>';
        }else{
          $str.='<p>他的id='.$_id.'====他的级别'.$cutOff.$name.'</p>';
        }
        $str.=$this->cid($_id,$pid);
    }
    return $str;
37}
public function finance_c()
{
   $w['type'] = '资产类';
   $w['parent_code'] = 0;
   $rs = Db::name('finance_class')
       -> field('id,code,name,parent_code')
       -> where($w)
        -> select();
   $str = '';
   foreach ($rs as $k => $v){
     $str.= '<p>一级name:'.$v['name'].'</p>';
     $str.=    $this -> cid($v['id'],0);
   }
   echo $str;
}

这个方法出来的效率慢,而且很绕。
方法2:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
public function getVoucherClass()
{
    $lists = Db::name('finance_class')->select();

    $lists = $this->getTree($lists);

    foreach($lists as $value){
      echo str_repeat('--', $value['level']), $value['name'].'<br />';
    }
10}

/**
* 递归实现无限极分类
* @param $array 分类数据
* @param $pid 父ID
* @param $level
* @return $list
*/
function getTree($array, $pid =0, $level = 0){
   static $list = [];
   foreach ($array as $key => $value){
     if ($value['parent_code'] == $pid){
        $value['level'] = $level;
         $list[] = $value;
         unset($array[$key]);
         $this->getTree($array, $value['id'],$level+1);
      }
   }
   return $list;
30}

无限极分类3:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
public function index()
   {
      $lists = \think\Db::table('ozyx_finance_class')->select();
      $lists = $this->getTree($lists,0);

      foreach ($lists as $k => $v) {
              $lists_one[$v['type']][]=$v;
      }

      // halt($lists_one);
      $this->assign('lists', $lists_one);

      return view();
   }

   /**
   * 无限极分类
   */
   function getTree($data, $pid)
   {
       $tree = '';
       foreach($data as $k => $v)
       {
         if($v['parent_code'] == $pid)
         {        
              $v['parent_code'] = $this->getTree($data, $v['id']);
              $tree[] = $v;
                 unset($data[$k]);
         }
       }
       return $tree;
   }


2 个回复

倒序浏览
~(。≧3≦)ノ⌒☆
回复 使用道具 举报
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马