<?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(' ', $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 $db = mysql_connect('localhost', 'root', 'root') or die('Can\'t connect to database'); ...
PHP递归按层级查找数据的方法是一种在PHP编程中常见的数据处理技术,特别适用于处理具有层级关系的数据,例如树形结构的菜单、组织架构图等。递归方法能够有效地减少重复代码的编写,并且使代码更加简洁易懂。 在...
本资源提供的"php递归实现无限级分类库",旨在帮助开发者轻松地处理这类问题。下面将详细阐述如何使用递归方法来实现无限级分类,并结合提供的`cate-master`文件进行解析。 首先,我们要理解递归的基本概念。递归是...
当处理树形结构(如分类)时,一个节点可能有多个子节点,每个子节点又可以有子节点,以此类推,形成无限级的结构。递归函数会从当前节点开始,逐级向下遍历,直到没有子节点为止。 2. **无限级分类**: 无限级...
在PHP中,递归常用于处理树形结构,因为树是由节点(每个节点可能有零个或多个子节点)构成的层次结构。 在给定的场景中,`tree.php` 文件很可能是实现递归生成树结构的PHP代码。这个文件可能包含一个函数,该函数...
"基于layui实现树形穿梭框"是layui框架中的一个组件,用于构建交互式的树状结构选择器,常用于权限管理、数据分类选择等场景。下面将详细介绍这个知识点。 1. layui框架基础: layui是一个轻量级的前端框架,包含...
基于递归实现的PHP树形菜单代码是一种在网页中以树状结构展示数据的方法。通常用于电子商务网站或需要分类展示的场景。递归是一种编程技巧,通过函数自己调用自己来解决问题。在这个场景下,递归函数遍历每一个分类...
3. **获取层级结构**:通过递归算法,将所有分类按照层级顺序排列,形成一个树形结构。这对于在前端展示分类菜单或导航栏特别有用。 4. **更新和删除分类**:更新分类属性,如名称或描述,以及删除分类及其所有子...
【作品名称】:基于php非递归实现的高性能的处理数组的层级关系、包括生成无限极分类、树状结构 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期...
树形表格(TreeGrid)是EasyUI中的一个特色组件,它结合了表格和树状结构的特点,允许数据以层级方式展示,常用于组织结构、目录结构等场景。在实现无限层级菜单时,我们需要考虑如何动态加载子节点以及如何进行数据...
在无限分类中,递归常被用来遍历层级关系,例如在数据库中的分类表中,每个类别可能有多个子类别,而这些子类别又可以有各自的子类,形成一种树状结构。PHP的递归函数可以遍历这种结构,展示所有层次。 接着,我们...
在PHP编程中,数组生成树是一种常见的数据结构处理方式,特别是在构建层级关系或者表示具有父子关系的数据时。这种技术能够帮助我们有效地组织和操作数据,例如在网站菜单、组织架构或者文件系统中。本篇文章将深入...
在PHP编程中,无限级分类是一项常见的需求,...以上就是PHP实现非递归无限级分类的方法,包括数据库设计、算法实现、数据结构优化以及前端展示。这种方式能够高效地处理大量分类数据,避免了递归可能导致的性能瓶颈。
这个"PHP MYSQL 用递归写的留言本核心程序"是一个示例,它展示了如何利用PHP和MySQL实现一个功能完善的留言系统。下面,我们将深入探讨这个系统的相关知识点。 首先,PHP是一种广泛使用的服务器端脚本语言,尤其...
在介绍thinkPHP实现递归循环栏目并按照树形结构无限极输出的方法时,需要掌握的核心知识点主要集中在以下几个方面: 首先,理解thinkPHP框架中递归的概念。递归是一种常见的编程技术,是指函数直接或间接调用自身的...
本文主要介绍了如何使用PHP语言在不使用递归的情况下,实现树形结构数据的构建。在计算机科学中,树是一种常见的数据结构,用来模拟具有层次关系的数据。递归是实现树形结构常用的方法,但在处理大数据量时,递归...
在PHP开发中,数据分类是常见的需求,...总之,PHP无限分类树形类的实现是一个强大的工具,它简化了多层级数据的管理和展示。通过理解和应用这个类库,你可以更高效地处理复杂的分类系统,提高代码的可维护性和扩展性。
本主题探讨的是如何通过一次集合遍历来实现树形结构,这在处理层级数据,如组织架构、文件系统或者菜单导航时非常有用。我们将主要关注Java编程语言以及Spring Boot框架中的应用。 首先,理解树形结构是至关重要的...