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

PHP 实现无限级分类的方法

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

本篇文章主要介绍了PHP 无限级分类的相关知识,具有很好的参考价值。下面跟着小编一起来看下吧

有一段时间没用过无限极分类,不巧今天又用到,所以特地去翻箱回顾以前。为了避免以后找起来麻烦,特地贴在这里。

<?php/** * 无限级分类 类 */class Category{ /**  * 返回一维数组  * @param [type] $cate 要递归的数组  * @param string $html 子级分类前要显示的缩进符号。默认 '─'  * @param integer $pid 父级分类ID。默认为 0,表示顶级分类  * @param integer $level level级,配合 $html 显示足够的缩进。默认为 1,表示顶级分类  * @return [type]   [description]  */ static public function unlimitedForLevel($cate, $html = '─', $pid = 0, $level = 1){  $arr = array();  foreach($cate as $v){   if($v['pid'] == $pid){    $v['level'] = $level;    $v['html'] = str_repeat($html, $level - 1);    $arr[] = $v;    $arr = array_merge($arr, $this->unlimitedForLevel($cate, $html, $v['id'], $level + 1));   }  }  return $arr; } /**  * 返回多维数组  * @param [type] $cate 要递归的数组  * @param string $name 子级分类在父分类数组中的 key  * @param integer $pid 父级分类ID。默认为0,表示顶级分类  * @return [type]  [description]  */ static public function unlimitedForlayer($cate, $name = 'child', $pid = 0){  $arr = array();  foreach($cate as $v){   if( $v['pid'] == $pid){    $v[$name] = self::unlimitedForlayer($cate, $name, $v['id']);    $arr[] = $v;   }  }  return $arr; } /**  * 传递子分类ID返回所有父级分类  * @param [type] $cate 要递归的数组  * @param [type] $id 子分类ID  * @return [type]  [description]  */ static public function getParents($cate, $id){  $arr = array();  foreach($cate as $v){   if($v['id'] == $id){    $arr[] = $v;    $arr = array_merge(self::getParents($cate, $v['pid']), $arr);   }  }  return $arr; } /**  * 传递父级分类ID返回所有子分类ID  * @param [type] $cate 要递归的数组  * @param [type] $pid 父级分类ID  * @return [type]  [description]  */ static public function getChildrenId($cate, $pid){  $arr = array();  foreach($cate as $v){   if($v['pid'] == $pid){    $arr[] = $v['i<div style="color:transparent">本&文来源gaodai^.ma#com搞#代!码网</div><strong>搞gaodaima代码</strong>d'];    $arr = array_merge($arr, self::getChildrenId($cate, $v['id']));   }  }  return $arr; } /**  * 传递父级分类ID返回所有子级分类  * @param [type] $cate 要递归的数组  * @param [type] $pid 父级分类ID  * @return [type]  [description]  */ static public function getChildren($cate, $pid){  $arr = array();  foreach($cate as $v){   if($v['pid'] == $pid){    $arr[] = $v;    $arr = array_merge($arr, self::getChildren($cate, $v['id']));   }  }  return $arr; }}?>

以上就是本文的全部内容,希望对大家的学习有所帮助。

相关推荐:

php数据访问之增删改查操作_php技巧

PHP实现的加密解密处理类_php技巧

PHP中time(),date(),mktime()区别介绍_php基础

以上就是PHP 实现无限级分类的方法的详细内容,更多请关注搞代码gaodaima其它相关文章!


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

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

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

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

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