>php教程 >php手册 >php递归方法实现无限分类实例

php递归方法实现无限分类实例

WBOY
WBOY원래의
2016-05-25 16:45:07933검색

数组代码如下:

<?php
$items = array(
    array(
        &#39;id&#39; => 1,
        &#39;pid&#39; => 0,
        &#39;name&#39; => &#39;一级11&#39;
    ) ,
    array(
        &#39;id&#39; => 11,
        &#39;pid&#39; => 0,
        &#39;name&#39; => &#39;一级12&#39;
    ) ,
    array(
        &#39;id&#39; => 2,
        &#39;pid&#39; => 1,
        &#39;name&#39; => &#39;二级21&#39;
    ) ,
    array(
        &#39;id&#39; => 10,
        &#39;pid&#39; => 11,
        &#39;name&#39; => &#39;二级22&#39;
    ) ,
    array(
        &#39;id&#39; => 3,
        &#39;pid&#39; => 1,
        &#39;name&#39; => &#39;二级23&#39;
    ) ,
    array(
        &#39;id&#39; => 12,
        &#39;pid&#39; => 11,
        &#39;name&#39; => &#39;二级24&#39;
    ) ,
    array(
        &#39;id&#39; => 13,
        &#39;pid&#39; => 12,
        &#39;name&#39; => &#39;三级31&#39;
    ) ,
    array(
        &#39;id&#39; => 9,
        &#39;pid&#39; => 1,
        &#39;name&#39; => &#39;二级25&#39;
    ) ,
);
?>

函数代码如下:

<?php
function formatTree($array, $pid = 0) {
    $arr = array();
    $tem = array();
    foreach ($array as $v) {
        if ($v[&#39;pid&#39;] == $pid) {
            $tem = formatTree($array, $v[&#39;id&#39;]);
            //判断是否存在子数组
            $tem && $v[&#39;son&#39;] = $tem;
            $arr[] = $v;
        }
    }
    return $arr;
}
?>

其中,数组一定要包含id和pid用以指定数组值之间的层级关系.


文章链接:

随便收藏,请保留本文地址!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.