• 技术文章 >php教程 >php手册

    无限级别菜单的实现(其实还是有限级别的^0^)

    2016-06-21 09:11:37原创273

    菜单


    明天(已经是今天了,呵呵)我会提供一个测试页面让大家来看(因为我在宿舍只能拨号上网,Ip地址不固定)

    */

    /** 递归显示子节点函数
    *
    *
    * @param $SearchPattern 查找的条件(like)
    * @param $BaseNum 节点的层数
    */

    function ListChildTree($SearchPattern,$BaseNum){
    global $Tree;//声明连接数据库的句柄为全局
    $Sql="select DepartmentId,DepartmentName from test where DepartmentId like '$SearchPattern'"; //查找孩子节点
    $QueryChild=$Tree->query($Sql);
    while($Result=$Tree->fetch_array($QueryChild)) { //取出孩子节点
    $Space="";
    for($j=0;$j<((strlen($SearchPattern)/3)-$BaseNum);$j++)
    $Space.=" "; //设置显示节点前面的距离,这里的空格的html被这里自动替换成" "了
    $ChildDepartment=trim($Result[0])."___";
    $ChildSql="select count(*) from test where DepartmentId like '$ChildDepartment'";//查找孩子节点的孩子节点
    $ChildResult=$Tree->query_first($ChildSql);
    $TableId="ta".trim($Result[0]); //设置表格Id
    $TablePic="ta".trim($Result[0])."pic"; //设置图片Id
    if($ChildResult[0]<1){//如果没有找到孩子节点的节点,则显示"-"图片
    ?>



    ?>


    ListChildTree($ChildDepartment,$BaseNum);//递归调用函数本身来显示其他孩子节点
    }//end if?>

    }//end function?>


    无限级菜单测试






    require("do_mySql.php");
    $Tree = new DB_Sql;
    $Tree->connect();//连接数据库,可根据需要换成自己的代码

    $Sql="select DepartmentId,DepartmentName from test where length(DepartmentId)=3";//提出最上层节点(祖宗节点),根据需要自己修改
    $Result=$Tree->query_first($Sql);
    ?>














    $FirstDepartment=$Result[0];
    $BaseNum=strlen($FirstDepartment)/3;//计算层数,其实这个有点多余,因为其必为第一层
    $SearchPattern=$FirstDepartment."___"; //设置查找条件
    ListChildTree($SearchPattern,$BaseNum); //显示祖宗节点的孩子节点
    ?>











    由于是测试表设计得非常的简单:

    CREATE TABLE test (
    id mediumint(8) unsigned NOT NULL auto_increment, #流水号
    DepartmentId varchar(100) NOT NULL default '', #单位代号
    DepartmentName varchar(100) NOT NULL default '', #单位名称
    KEY id (id)
    )

    数据插入的代码我在这里就不那出来给大家了(很容易写,相信大家都能写出来)

    数据表的规则为:

    001为第一级(如果999个不够,请自行添加)
    001001为001的第一个子节点,001002为001的第二个子节点
    001001001为001001的第一个子节点,以此类推……

    我这里只设置了一个"祖宗"(001),所以在程序中就直接调用了,可根据需要自己来设置,并对代码作简单的修改即可!

    好了,就到这里了,如果大家有问题欢迎和我探讨!最好祝大家今天工作愉快!
    先吸颗烟在睡觉!好累!(因为刚刚写了一个webFtp,如果哪位兄弟姐妹需要请mail我)
    */


    ?>



    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:nbsp quot gt lt SearchPattern
    PHP编程就业班

      相关课程推荐

    • javascript初级视频教程

      《javascript初级视频教程》是JavaScript的入门课程,旨在让大家认识,了解JavaScript的常见概念

      JavaScript教程80316次播放


    • jquery 基础视频教程

      jQuery 很容易学习,希望通过我们的《jquery 基础视频教程》可以帮助大家来更好的学习jQuery。 jQuery 是一个 JavaScript 库,简化了 JavaScript 编程。

      jQuery教程50143次播放


    • javascript三级联动视频教程

      《javascript三级联动视频教程》介绍了javascript开发的三级联动功能,该功能在日常使用中还是经常能用的到的一个。

      JavaScript教程29622次播放


    • 独孤九贱(3)_JavaScript视频教程

      javascript是运行在浏览器上的脚本语言,连续多年,被评为全球最受欢迎的编程语言。是前端开发必备三大法器中,最具杀伤力。如果前端开发是降龙十八掌,好么javascript就是第18掌:亢龙有悔。没有它,你的前端生涯是不完整的。《php.cn独孤九贱(3)-JavaScript视频教程》课程特色:php中文网原创幽默段子系列课程,以恶搞,段子为主题风格的php视频教程!轻松的教学风格,简短的教学模式,让同学们在不知不觉中,学会了javascript知识。

      JavaScript教程118610次播放


    • 独孤九贱(6)_jQuery视频教程

      jQuery是一个快速、简洁的JavaScript框架。设计的宗旨是“write Less,Do More”,即倡导写更少的代码,做更多的事情。它封装JavaScript常用的功能代码,提供一种简便的JavaScript设计模式,优化HTML文档操作、事件处理、动画设计和Ajax交互。 核心特性可以总结为:具有独特的链式语法和短小清晰的多功能接口;具有高效灵活的css选择器,并且可对CSS选择器进行扩展;拥有便捷的插件扩展机制和丰富的插件。兼容各种主流浏览器,如IE 6.0+、FF 1.5+、Safari 2.0+、Opera 9.0+等,是全球最流行的前端开发框架之一。PHP中文网根据最新版本,独家录制jQuery最新视频教程,回馈PHP中文网的新老用户。

      jQuery教程97949次播放


    全部评论我要评论

  • 取消发布评论发送
  • 1/1