• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

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

php 搞代码 3年前 (2022-01-21) 31次浏览 已收录 0个评论

本篇文章给大家带来的内容是介绍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 -><b>/本文来源gao@!dai!ma.com搞$$代^@码5网@</b><strong>搞代gaodaima码</strong> 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 = \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如何实现无限极分类?无限极分类的三种实现方法(代码详解)的详细内容,更多请关注搞代码gaodaima其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:php如何实现无限极分类?无限极分类的三种实现方法(代码详解)
喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址