`
ldl_xz
  • 浏览: 68871 次
  • 性别: Icon_minigender_1
  • 来自: 南京
社区版块
存档分类
最新评论

php实现无限级树型菜单(函数递归算法)

 
阅读更多

大概步骤如下: 首先到数据库取数据,放到一个数组, 然后把数据转化为一个树型状的数组, 最后把这个树型状的数组转为html代码。 也可以将第二步和第三步合为一步。

<!--more-->

详细如下: 1。数据库设计: 脚本如下:

CREATE TABLE `bg_cate` (
`cate_Id` int(30) unsigned NOT NULL AUTO_INCREMENT,
`cate_ParentId` int(30) unsigned DEFAULT '0',
`cate_Name` varchar(100) NOT NULL,
`cate_Intro` varchar(500) DEFAULT NULL,
`cate_Order` int(30) unsigned DEFAULT '0',
`cate_Icon` varchar(100) DEFAULT NULL,
PRIMARY KEY (`cate_Id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 AUTO_INCREMENT=34 ;

-- 
-- 导出表中的数据 `bg_cate`
--

INSERT INTO `bg_cate` (`cate_Id`, `cate_ParentId`, `cate_Name`, `cate_Intro`, `cate_Order`, `cate_Icon`) VALUES 
(4, 0, '往事如风', '记录往事', 0, 'icons/6.gif'),
(5, 0, '水煮三国', '品位三国智慧', 0, 'icons/3.gif'),
(2, 0, '技术学习', '平时学习的一些笔记,欢迎批评指正。', 0, 'icons/18.gif'),
(3, 0, '生活点滴', '记录生活点滴', 0, 'icons/2.gif'),
(6, 0, '栀子花开', '青春无限', 0, 'icons/8.gif'),
(7, 0, '假日休闲', '悠闲、自在', 0, 'icons/24.gif'),
(8, 2, 'html', 'html学习', 0, 'icons/1.gif'),
(9, 2, 'css', 'css学习', 0, 'icons/1.gif'),
(10, 2, 'php', 'php学习', 0, 'icons/18.gif'),
(11, 10, 'php基础知识', 'php基础知识', 0, 'icons/1.gif'),
(12, 10, 'oop', 'oop', 0, 'icons/1.gif'),
(13, 10, 'php安全', '讲述php安全', 0, 'icons/1.gif'),
(14, 10, 'seagull framework', 'seagull framework', 0, 'icons/1.gif'),
(15, 2, 'javascript', 'javascript学习', 0, 'icons/1.gif'),
(16, 2, '设计模式', NULL, 0, 'icons/1.gif'),
(17, 2, '软件工程', '软件工程学习', 0, 'icons/1.gif'),
(18, 3, '厦门生活', '厦门生活', 0, 'icons/8.gif'),
(19, 3, '大学生活', '大学生活', 0, 'icons/8.gif'),
(20, 3, '童年生活', '童年生活', 0, 'icons/15.gif'),
(21, 19, '学习', '学习', 0, 'icons/1.gif'),
(22, 19, '运动', '运动', 0, 'icons/16.gif'),
(23, 19, '旅游', '旅游', 0, 'icons/24.gif'),
(24, 22, '排球', '排球', 0, 'icons/9.gif'),
(25, 22, '篮球', '篮球', 0, 'icons/9.gif'),
(26, 22, '羽毛球', '羽毛球', 0, 'icons/9.gif'),
(27, 22, '乒乓球', '乒乓球', 0, 'icons/9.gif');

2。到数据库取数据,放到数组。

require_once './classes/MyDB.php';
$con = MyDB::singleton(); 
$sql = <<<SQL
    select * from bg_cate cate 
SQL;
$data = $con->getAll($sql);
//print_r($data);

数据库操作我用的是pear类库。 最后的$data的数据格式如下:

Array
(
    [0] => Array
        (
            [cate_Id] => 4
            [cate_ParentId] => 0
            [cate_Name] => 往事如风
            [cate_Intro] => 记录往事
            [cate_Order] => 0
            [cate_Icon] => icons/6.gif
        )

    [1] => Array
        (
            [cate_Id] => 5
            [cate_ParentId] => 0
            [cate_Name] => 水煮三国
            [cate_Intro] => 品位三国智慧
            [cate_Order] => 0
            [cate_Icon] => icons/3.gif
        )
。。。。。。

3。把上一步的数据转为树型状的数组 代码如下:

function getTree($data, $pId)
{
$tree = '';
foreach($data as $k => $v)
{
   if($v['cate_ParentId'] == $pId)
   {         //父亲找到儿子
    $v['cate_ParentId'] = getTree($data, $v['cate_Id']);
    $tree[] = $v;
    //unset($data[$k]);
   }
}
return $tree;
}
$tree = getTree($data, 0);

最后输出$tree的数据格式为:

Array
(
    [0] => Array
        (
            [cate_Id] => 4
            [cate_ParentId] => 
            [cate_Name] => 往事如风
            [cate_Intro] => 记录往事
            [cate_Order] => 0
            [cate_Icon] => icons/6.gif
        )

    [1] => Array
        (
            [cate_Id] => 5
            [cate_ParentId] => 
            [cate_Name] => 水煮三国
            [cate_Intro] => 品位三国智慧
            [cate_Order] => 0
            [cate_Icon] => icons/3.gif
        )

    [2] => Array
        (
            [cate_Id] => 2
            [cate_ParentId] => Array
                (
                    [0] => Array
                        (
                            [cate_Id] => 8
                            [cate_ParentId] => 
                            [cate_Name] => html
                            [cate_Intro] => html学习
                            [cate_Order] => 0
                            [cate_Icon] => icons/1.gif
                        )
。。。。。。。。。。。

4。把树型状数组转为html 代码如下:

function procHtml($tree)
{
$html = '';
foreach($tree as $t)
{
   if($t['cate_ParentId'] == '')
   {
    $html .= "<li>{$t['cate_Name']}</li>";
   }
   else
   {
    $html .= "<li>".$t['cate_Name'];
    $html .= procHtml($t['cate_ParentId']);
    $html = $html."</li>";
   }
}
return $html ? '<ul>'.$html.'</ul>' : $html ;
}
echo procHtml($tree);
输出的html的代码格式为:
<ul>
<li>往事如风</li>
<li>水煮三国</li>
<li>技术学习
   <ul>
    <li>html</li>
    <li>css</li>
    <li>php
     <ul>
      <li>php基础知识</li>
      <li>oop</li>
      <li>php安全</li>
。。。。。。。。。。。。。。。。

5。也可以把第3和第4步的代码合在一起,代码如下:
function getTree($data, $pId)
{
$html = '';
foreach($data as $k => $v)
{
   if($v['cate_ParentId'] == $pId)
   {         //父亲找到儿子
    $html .= "<li>".$v['cate_Name'];
    $html .= getTree($data, $v['cate_Id']);
    $html = $html."</li>";
   }
}
return $html ? '<ul>'.$html.'</ul>' : $html ;
}
echo getTree($data, 0);

转载自:http://www.9958.pw/post/php_cat_pid

分享到:
评论

相关推荐

    PHP无限级树型分类

    总之,PHP无限级树型分类是一项实用的技术,它结合了递归算法和数据库操作,帮助开发者构建灵活且易于管理的分类系统。通过理解和掌握这一技术,我们可以提高在复杂数据结构处理上的能力,从而更好地服务于各种Web...

    php创建无限级树型菜单

    总结一下,创建无限级树型菜单的PHP代码涉及到数据库操作、递归算法、数组操作以及HTML生成等多个方面。实现这一功能的关键在于: - 理解树型数据结构。 - 掌握递归函数的使用方法。 - 能够有效地利用数据库查询来...

    无限级可刷新Js树型菜单

    2. **递归**:无限级树型菜单通常需要递归算法来处理。当数据源是多级嵌套的对象数组时,可以通过递归函数遍历并生成相应的HTML结构。递归函数会调用自身处理每个子节点,直到所有层级都被遍历完。 3. **事件监听**...

    树型菜单的构造算法

    本文将深入探讨“树型菜单的构造算法”,并结合标签“源码”和“工具”,我们将从代码实现的角度出发,解析如何创建这样的数据结构。 首先,树型菜单的基本概念是它具有层次结构,类似于自然界中的树木,每个节点...

    树型数据结构中递归算法的实现.pdf

    在树型结构中,递归算法的应用广泛且重要,它通过函数自我调用的方式,处理树中节点相关的操作。 递归算法是一种在函数调用自身进行自我复制的过程,通过这种方式可以将大问题分解为小问题,直至解决。在树型数据...

    一个基于C#实现的递归法生成的树型菜单的程序源码

    综上所述,这个基于C#实现的递归法生成的树型菜单程序源码涵盖了C#编程、数据结构、递归算法、UI设计、事件处理、面向对象编程等多个核心IT概念,对于学习和理解C#应用程序开发具有很高的参考价值。

    ASP树型无限级菜单源码

    综上所述,ASP树型无限级菜单源码是基于ASP技术实现的,结合数据库存储、递归算法、前端交互等多种技术,为用户提供直观且易于操作的多级菜单展示。同时,具备后台管理功能,使得对菜单的维护更加便捷。在实际应用中...

    js无限级分类源码,无限分类,树型菜单,分类,

    在JavaScript中实现无限级分类的树型菜单,需要考虑以下几个核心知识点: 1. 数据结构:首先,我们需要定义一个数据结构来存储分类信息,这通常是一个对象数组,每个对象包含分类的ID、名称、父分类ID等属性,以及...

    c# .net 实现无限级分类 树型分类 带数据库

    在C# .NET开发中,实现无限级分类和树型分类是常见的需求,尤其是在构建具有层级结构的数据模型,如组织架构、目录结构或商品分类时。这类问题通常涉及到递归和数据存储,本教程将围绕如何使用C# .NET来处理这种场景...

    一个php树型菜单类库

    总之,PHP树型菜单类库是基于数据结构和算法设计的,它简化了在PHP项目中处理和展示层次结构数据的过程。理解并掌握这些基本概念,不仅可以更好地运用这个类库,还能提升你的编程能力,为解决更复杂的问题打下坚实的...

    js树型菜单

    JavaScript树型菜单是一种...总的来说,js树型菜单是前端开发中的重要技能,涉及到DOM操作、事件处理、CSS样式、数据结构和算法等多个方面,熟练掌握这些知识点能帮助开发者构建出功能强大且用户体验良好的树型菜单。

    C#树型菜单

    3. 递归操作:在处理树型结构时,递归函数常被用于遍历或操作所有节点。例如,查找特定值的节点、添加或删除节点等。 4. 自定义绘制:虽然`TreeView`控件提供了默认的渲染,但为了满足个性化需求,可以重写`...

    web中用静态树和递归算法制作动态树

    3. 实现递归算法的`createTree()`方法,根据节点的PID关系构建树结构。 4. 将生成的HTML代码通过JspWriter写入JSP页面,由客户端渲染显示。 这种方法的优点是灵活性高,可以适应各种复杂的数据结构和动态更新需求。...

    C#树型递归

    "C#树型递归"指的是在C#编程语言中利用递归算法处理树状数据结构的问题。下面将详细介绍这两个主题。 首先,树是一种非线性的数据结构,由节点和边构成,每个节点可以有零个或多个子节点。在计算机科学中,树常用于...

    二叉树后序遍历的非递归算法。.doc

    本实验主要探讨了如何使用非递归算法实现二叉树的后序遍历。 首先,理解非递归算法的关键在于控制节点的访问时机。在后序遍历中,一个节点的访问条件是其左右子树都已被访问。因此,我们需要用栈来保存待访问的节点...

    ASP.NET TreeView树型菜单操作实例(代码调试通过).doc

    5. **递归算法**:在处理层次结构数据时,递归函数是构建和遍历`TreeView`的关键技术。 6. **数据集管理**:熟悉如何使用`DataSet`和`DataTable`来存储和检索数据,这是`TreeView`数据绑定的基础。 7. **用户交互...

    ASP+ACCESS动态二级树形产品导航菜单(黄生原创作品)

    动态二级树形产品导航菜单的核心在于递归算法的实现。在ASP中,通常会定义一个函数,该函数根据父类别ID查询数据库,获取子类别,然后在HTML中逐层展开。每次递归调用都是为当前类别添加子项,直到没有子项为止。...

    递归法读取数据库树型结构示例

    总结起来,实现“递归法读取数据库树型结构”涉及数据库查询、递归算法、数据结构操作和用户界面控件的使用。通过这种方式,我们可以高效地处理和展示数据库中的层次数据,提供直观的用户体验。在实际项目中,可以...

Global site tag (gtag.js) - Google Analytics