• 无限极分类


    1. ?php 
    2.         /*
    3.         *     无限极分类 类
    4.         */
    5.     header("Content-Type: text/html; charset=UTF-8");
    6.     Class Category {
    7.         //组合一维数组
    8.         Static Public function unlimitedForLevel ($cate, $html = '--', $pid = 0, $level = 0) {
    9.             $arr = array();
    10.             foreach ($cate as $k => $v) {
    11.                 if ($v['pid'] == $pid) {
    12.                     $v['level'] = $level + 1;
    13.                     $v['html']  = str_repeat($html, $level);
    14.                     $arr[] = $v;
    15.                     $arr = array_merge($arr, self::unlimitedForLevel($cate, $html, $v['id'], $level + 1));
    16.                 }
    17.             }
    18.             return $arr;
    19.         }
    20.         //组合多维数组
    21.         Static Public function unlimitedForLayer ($cate, $name = 'child', $pid = 0) {
    22.             $arr = array();
    23.             foreach ($cate as $v) {
    24.                 if ($v['pid'] == $pid) {
    25.                     $v[$name] = self::unlimitedForLayer($cate, $name, $v['id']);
    26.                     $arr[] = $v;
    27.                 }
    28.             }
    29.             return $arr;
    30.         }
    31.         //传递一个子分类ID返回所有的父级分类  
    32.         Static Public function getParents ($cate, $id) {
    33.             $arr = array();
    34.             foreach ($cate as $v) {
    35.                 if ($v['id'] == $id) {
    36.                     $arr[] = $v;
    37.                     $arr = array_merge(self::getParents($cate, $v['pid']), $arr); 
    38.                 }
    39.             }
    40.             return $arr;
    41.         }
    42.         //传递一个父级分类ID返回所有子分类ID
    43.         Static Public function getChildsId ($cate, $pid) {
    44.             $arr = array();
    45.             foreach ($cate as $v) {
    46.                 if ($v['pid'] == $pid) {
    47.                     $arr[] = $v['id'];
    48.                     $arr = array_merge($arr, self::getChildsId($cate, $v['id']));
    49.                 }
    50.             }
    51.             return $arr;
    52.         }
    53.         //传递一个父级分类ID返回所有子分类
    54.         Static Public function getChilds ($cate, $pid) {
    55.             $arr = array();
    56.             foreach ($cate as $v) {
    57.                 if ($v['pid'] == $pid) {
    58.                     $arr[] = $v;
    59.                     $arr = array_merge($arr, self::getChilds($cate, $v['id']));
    60.                 }
    61.             }
    62.             return $arr;
    63.         }
    64.     }
    65. $cate = array(
    66.     0 => array('id' => 1, 'pid' => 0, 'name' => '江西省'),
    67.     1 => array('id' => 2, 'pid' => 0, 'name' => '浙江省'),
    68.     2 => array('id' => 3, 'pid' => 1, 'name' => '上饶市'),
    69.     3 => array('id' => 4, 'pid' => 3, 'name' => '广丰县'),
    70.     4 => array('id' => 5, 'pid' => 2, 'name' => '杭州市'),
    71.     5 => array('id' => 6, 'pid' => 5, 'name' => '西湖'),
    72.     6 => array('id' => 7, 'pid' => 6, 'name' => '断桥'),
    73.  );
    74.  //print_r(Category::unlimitedForLevel($cate));
    75. print_r(Category::unlimitedForLayer($cate));
    76.  //print_r(Category::getParents($cate,7));
    77.  //print_r(Category::getChildsId($cate,2));
    78.  //print_r(Category::getChilds($cate,2));
    79.  // PHP交流群 278528223
    80.  ?>
     
  • 相关阅读:
    U盘启动盘的制作与U盘重装系统
    如何使用鲁大师进行驱动备份
    电子科大POJ "3*3矩阵的乘法"
    数字图像处理之sobel边缘检测
    (续)一个demo弄清楚位图在内存中的存储结构
    VC++6.0出现no compile tool is associated with the extension.解决方法
    显卡参数简单介绍
    数字图像处理之位图在计算机中的存储结构
    图像处理之边缘检测概述
    linux下mysql数据库的操作
  • 原文地址:https://www.cnblogs.com/chuanqideya/p/6039922.html
Copyright © 2020-2023  润新知