>백엔드 개발 >PHP 튜토리얼 >PHP에서 Infinitus 분류를 구현하는 방법 Infinitus 분류의 세 가지 구현 방법(자세한 코드 설명)

PHP에서 Infinitus 분류를 구현하는 방법 Infinitus 분류의 세 가지 구현 방법(자세한 코드 설명)

青灯夜游
青灯夜游앞으로
2018-10-29 16:16:475942검색

이 글의 내용은 PHP에서 Infinitus 분류를 구현하는 방법을 소개하는 것입니다. Infinitus 분류의 세 가지 구현 방법(상세 코드 설명)입니다. 도움이 필요한 친구들이 참고할 수 있기를 바랍니다.

Infinitus 카테고리 1:

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'] a8093152e673feb7aba1828c43532094 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 07712f3ff3ffe56750e7faf0f297fe4b judeg($_id); $i++){
          $cutOff.='-';
        }
        if($_id == $pid){
          $str.='e388a4556c0f65e1904146cc1a846bee他的id='.$_id.'====他的级别'.$cutOff.$name.'94b3e26ee717c64999d7867364b1b4a3';
        }else{
          $str.='e388a4556c0f65e1904146cc1a846bee他的id='.$_id.'====他的级别'.$cutOff.$name.'94b3e26ee717c64999d7867364b1b4a3';
        }
        $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.= 'e388a4556c0f65e1904146cc1a846bee一级name:'.$v['name'].'94b3e26ee717c64999d7867364b1b4a3';
     $str.=    $this -> cid($v['id'],0);
   }
   echo $str;
}

이 방법은 느리고 복잡합니다.

방법 2:

public function getVoucherClass()
{
    $lists = Db::name('finance_class')->select();

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

    foreach($lists as $value){
      echo str_repeat(&#39;--&#39;, $value[&#39;level&#39;]), $value[&#39;name&#39;].&#39;<br />&#39;;
    }
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[&#39;parent_code&#39;] == $pid){
        $value[&#39;level&#39;] = $level;
         $list[] = $value;
         unset($array[$key]);
         $this->getTree($array, $value[&#39;id&#39;],$level+1);
      }
   }
   return $list;
30}

무한 분류 3:

 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;
    }

데이터 테이블 구조:

위 내용은 PHP에서 Infinitus 분류를 구현하는 방법 Infinitus 분류의 세 가지 구현 방법(자세한 코드 설명)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 cnblogs.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제