php如何实现无限极分类?无限极分类的三种实现方法(代码详解)

如果下载的源码需要作者授权,请更换源码。本站免费分享资源不会增加授权

本篇文章给大家带来的内容是介绍php如何实现无限极分类?无限极分类的三种实现方法(代码详解)。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。

无限极分类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'] <> 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:

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:

 public function index()     {        $lists = thinkDb::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如何实现无限极分类?无限极分类的三种实现方法(代码详解)

本文由(壳先生)整理自网络,如转载请注明出处:https://www.mrshell.com;
本站发布的内容若侵犯到您的权益,请邮件联系 i@mrshell.com 删除,我们将及时处理!
===========================================================================

1. 本站大部分下载资源收集于网络,不保证其完整性以及安全性,请下载后自行测试。
2. 本站资源仅供学习和交流使用,版权归资源原作者所有,请在下载后24小时之内自觉删除。
3. 不得使用于非法商业用途,商用请支持正版!不得违反国家法律,否则后果自负!
4. 若作商业用途,请购买正版,由于未及时购买和付费发生的侵权行为,与本站无关。
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 本站资源售价只是赞助,收取费用仅维持本站的日常运营所需!

=================================================================

壳先生 » php如何实现无限极分类?无限极分类的三种实现方法(代码详解)

发表评论

提供最优质的资源集合

立即查看 了解详情