`
yl.fighter
  • 浏览: 258791 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

PHP 递归实现层级树状展现数据

阅读更多

 

<?php

$db = mysql_connect('localhost', 'root', 'root') or die('Can\'t connect to database');
mysql_select_db('test') or die('Can\'t find database : test');
$result = mysql_query('select id, fid, name from tree');
while($arr = mysql_fetch_array($result)){
    $data[] = array(
        'id' => $arr['id'], 
        'fid' => $arr['fid'],
        'name' => $arr['name'], 
    );
}

// 将数据按照缩进简单排列 见图1
function data2arr($tree, $rootId = 0, $level = 0) {
    foreach($tree as $leaf) {
        if($leaf['fid'] == $rootId) {
            echo str_repeat('&nbsp;&nbsp;&nbsp;&nbsp;', $level) . $leaf['id'] . ' ' . $leaf['name'] . '<br/>';
            foreach($tree as $l) {
                if($l['fid'] == $leaf['id']) {
                    data2arr($tree, $leaf['id'], $level + 1);
                    break;
                }
            }
        }
    }
}

data2arr($data);
echo '<br/>-----------------------------------------------------------------------<br/>';

// 将数据按照所属关系封装 见图2
function arr2tree($tree, $rootId = 0) {
    $return = array();
    foreach($tree as $leaf) {
        if($leaf['fid'] == $rootId) {
            foreach($tree as $subleaf) {
                if($subleaf['fid'] == $leaf['id']) {
                    $leaf['children'] = arr2tree($tree, $leaf['id']);
                    break;
                }
            }
            $return[] = $leaf;
        }
    }
    return $return;
}

$tree = arr2tree($data);
print_r($tree);
echo '<br/>-----------------------------------------------------------------------<br/>';

// 将数据使用HTML再次展现 见图3
function tree2html($tree) {
    echo '<ul>';
    foreach($tree as $leaf) {
        echo '<li>' .$leaf['name'];
        if(! empty($leaf['children'])) tree2html($leaf['children']);
        echo '</li>';
    }
    echo '</ul>';
}

tree2html($tree);

 

 

 

图 1:

 图 2:



  图 3:


  • 大小: 11.6 KB
  • 大小: 25.3 KB
  • 大小: 11.9 KB
分享到:
评论

相关推荐

    PHP递归实现层级树状展开

    本文实例为大家分享了PHP递归实现层级树状展开的主要代码,供大家参考,具体内容如下 效果图: 实现代码: &lt;?php $db = mysql_connect('localhost', 'root', 'root') or die('Can\'t connect to database'); ...

    PHP使用递归按层级查找数据的方法

    PHP递归按层级查找数据的方法是一种在PHP编程中常见的数据处理技术,特别适用于处理具有层级关系的数据,例如树形结构的菜单、组织架构图等。递归方法能够有效地减少重复代码的编写,并且使代码更加简洁易懂。 在...

    php递归实现无限级分类库

    本资源提供的"php递归实现无限级分类库",旨在帮助开发者轻松地处理这类问题。下面将详细阐述如何使用递归方法来实现无限级分类,并结合提供的`cate-master`文件进行解析。 首先,我们要理解递归的基本概念。递归是...

    php递归获取子级,父级,无限极分类,带demo,效率超高

    当处理树形结构(如分类)时,一个节点可能有多个子节点,每个子节点又可以有子节点,以此类推,形成无限级的结构。递归函数会从当前节点开始,逐级向下遍历,直到没有子节点为止。 2. **无限级分类**: 无限级...

    PHP递归生成TREE

    在PHP中,递归常用于处理树形结构,因为树是由节点(每个节点可能有零个或多个子节点)构成的层次结构。 在给定的场景中,`tree.php` 文件很可能是实现递归生成树结构的PHP代码。这个文件可能包含一个函数,该函数...

    基于layui实现树形穿梭框

    "基于layui实现树形穿梭框"是layui框架中的一个组件,用于构建交互式的树状结构选择器,常用于权限管理、数据分类选择等场景。下面将详细介绍这个知识点。 1. layui框架基础: layui是一个轻量级的前端框架,包含...

    基于递归实现的php树形菜单代码

    基于递归实现的PHP树形菜单代码是一种在网页中以树状结构展示数据的方法。通常用于电子商务网站或需要分类展示的场景。递归是一种编程技巧,通过函数自己调用自己来解决问题。在这个场景下,递归函数遍历每一个分类...

    php递归实现无限级分类库.zip

    3. **获取层级结构**:通过递归算法,将所有分类按照层级顺序排列,形成一个树形结构。这对于在前端展示分类菜单或导航栏特别有用。 4. **更新和删除分类**:更新分类属性,如名称或描述,以及删除分类及其所有子...

    基于php非递归实现的高性能的处理数组的层级关系、包括生成无限极分类、树状结构

    【作品名称】:基于php非递归实现的高性能的处理数组的层级关系、包括生成无限极分类、树状结构 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期...

    easyUI-树形表格(TreeGrid)实现无限层级菜单

    树形表格(TreeGrid)是EasyUI中的一个特色组件,它结合了表格和树状结构的特点,允许数据以层级方式展示,常用于组织结构、目录结构等场景。在实现无限层级菜单时,我们需要考虑如何动态加载子节点以及如何进行数据...

    自己写的php 递归无限分类 附有sql文件

    在无限分类中,递归常被用来遍历层级关系,例如在数据库中的分类表中,每个类别可能有多个子类别,而这些子类别又可以有各自的子类,形成一种树状结构。PHP的递归函数可以遍历这种结构,展示所有层次。 接着,我们...

    php数组生成树

    在PHP编程中,数组生成树是一种常见的数据结构处理方式,特别是在构建层级关系或者表示具有父子关系的数据时。这种技术能够帮助我们有效地组织和操作数据,例如在网站菜单、组织架构或者文件系统中。本篇文章将深入...

    PHP无限级分类-非递归

    在PHP编程中,无限级分类是一项常见的需求,...以上就是PHP实现非递归无限级分类的方法,包括数据库设计、算法实现、数据结构优化以及前端展示。这种方式能够高效地处理大量分类数据,避免了递归可能导致的性能瓶颈。

    PHP MYSQL 用递归写的留言本核心程序

    这个"PHP MYSQL 用递归写的留言本核心程序"是一个示例,它展示了如何利用PHP和MySQL实现一个功能完善的留言系统。下面,我们将深入探讨这个系统的相关知识点。 首先,PHP是一种广泛使用的服务器端脚本语言,尤其...

    thinkPHP实现递归循环栏目并按照树形结构无限极输出的方法

    在介绍thinkPHP实现递归循环栏目并按照树形结构无限极输出的方法时,需要掌握的核心知识点主要集中在以下几个方面: 首先,理解thinkPHP框架中递归的概念。递归是一种常见的编程技术,是指函数直接或间接调用自身的...

    PHP树-不需要递归的实现方法

    本文主要介绍了如何使用PHP语言在不使用递归的情况下,实现树形结构数据的构建。在计算机科学中,树是一种常见的数据结构,用来模拟具有层次关系的数据。递归是实现树形结构常用的方法,但在处理大数据量时,递归...

    php无限分类树形类的实现.zip

    在PHP开发中,数据分类是常见的需求,...总之,PHP无限分类树形类的实现是一个强大的工具,它简化了多层级数据的管理和展示。通过理解和应用这个类库,你可以更高效地处理复杂的分类系统,提高代码的可维护性和扩展性。

    一次集合遍历实现树形结构 - server

    本主题探讨的是如何通过一次集合遍历来实现树形结构,这在处理层级数据,如组织架构、文件系统或者菜单导航时非常有用。我们将主要关注Java编程语言以及Spring Boot框架中的应用。 首先,理解树形结构是至关重要的...

Global site tag (gtag.js) - Google Analytics