PHP实现无限级分类递归方法

效果:

实现代码:

<?php

include("tree.class.php");

//具有这个结构的数组,不是这样的话,可以改类的实现

$list = array(

    1 => array('id' => '1','pid' => 0,'name' => '一级栏目一'),

    2 => array('id' => '2','name' => '一级栏目二'),

    3 => array('id' => '3','pid' => 1,'name' => '二级栏目一'),

    4 => array('id' => '4','name' => '二级栏目二'),

    5 => array('id' => '5','pid' => 2,'name' => '二级栏目三'),

    6 => array('id' => '6','pid' => 3,'name' => '三级栏目一'),

    7 => array('id' => '7','name' => '三级栏目二')

);

$tree = new tree($list);

$html = "<select name='cat'>";

$str = "<option value=$id $selected>$spacer$name</option>";

$html .= $tree->get_tree(0,$str,$selected=4);

$html .= "</select>";

echo($html);

?>

tree.class.php:

<?php

/**

* 通用的树型类,可以生成任何树型结构

*/

class tree {

/**

* 生成树型结构所需要的2维数组

* @var array

*/

public $arr = array();

/**

* 生成树型结构所需修饰符号,可以换成图片

* @var array

*/

public $icon = array('│','├','└');

public $nbsp = "&nbsp;";

/**

* @access private

*/

public $ret = '';

/**

* 构造函数,初始化类

* @param array 2维数组,例如:

* array(

*      1 => array('id'=>'1','parentid'=>0,'name'=>'一级栏目一'),

*      2 => array('id'=>'2','name'=>'一级栏目二'),

*      3 => array('id'=>'3','parentid'=>1,'name'=>'二级栏目一'),

*      4 => array('id'=>'4','name'=>'二级栏目二'),

*      5 => array('id'=>'5','parentid'=>2,'name'=>'二级栏目三'),

*      6 => array('id'=>'6','parentid'=>3,'name'=>'三级栏目一'),

*      7 => array('id'=>'7','name'=>'三级栏目二')

*      )

*/

public function __construct($arr=array()){

       $this->arr = $arr;

  $this->ret = '';

  return is_array($arr);

}

    /**

* 得到父级数组

* @param int

* @return array

*/

public function get_parent($myid){

$newarr = array();

if(!isset($this->arr[$myid])) return false;

$pid = $this->arr[$myid]['parentid'];

$pid = $this->arr[$pid]['parentid'];

if(is_array($this->arr)){

foreach($this->arr as $id => $a){

if($a['parentid'] == $pid) $newarr[$id] = $a;

}

}

return $newarr;

}

    /**

* 得到子级数组

* @param int

* @return array

*/

public function get_child($myid){

$a = $newarr = array();

if(is_array($this->arr)){

foreach($this->arr as $id => $a){

if($a['parentid'] == $myid) $newarr[$id] = $a;

}

}

return $newarr ? $newarr : false;

}

    /**

* 得到当前位置数组

* @param int

* @return array

*/

public function get_pos($myid,&$newarr){

$a = array();

if(!isset($this->arr[$myid])) return false;

        $newarr[] = $this->arr[$myid];

$pid = $this->arr[$myid]['parentid'];

if(isset($this->arr[$pid])){

   $this->get_pos($pid,$newarr);

}

if(is_array($newarr)){

krsort($newarr);

foreach($newarr as $v){

$a[$v['id']] = $v;

}

}

return $a;

}

    /**

* 得到树型结构

* @param int ID,表示获得这个ID下的所有子级

* @param string 生成树型结构的基本代码,例如:"<option value=$id $selected>$spacer$name</option>"

* @param int 被选中的ID,比如在做树型下拉框的时候需要用到,不填默认选第一个

* @return string

*/

public function get_tree($myid,$sid = 0,$adds = '',$str_group = ''){

$number=1;

$child = $this->get_child($myid);

if(is_array($child)){

   $total = count($child);

foreach($child as $id=>$value){

$j=$k='';

if($number==$total){

$j .= $this->icon[2];

}else{

$j .= $this->icon[1];

$k = $adds ? $this->icon[0] : '';

}

$spacer = $adds ? $adds.$j : '';

$selected = $id==$sid ? 'selected' : '';

@extract($value);

$parentid == 0 && $str_group ? eval("$nstr = "$str_group";") : eval("$nstr = "$str";");

$this->ret .= $nstr;

$nbsp = $this->nbsp;

$this->get_tree($id,$sid,$adds.$k.$nbsp,$str_group);

$number++;

}

}

return $this->ret;

}

    /**

* 同上一方法类似,但允许多选

*/

public function get_tree_multi($myid,$adds = ''){

$number=1;

$child = $this->get_child($myid);

if(is_array($child)){

   $total = count($child);

foreach($child as $id=>$a){

$j=$k='';

if($number==$total){

$j .= $this->icon[2];

}else{

$j .= $this->icon[1];

$k = $adds ? $this->icon[0] : '';

}

$spacer = $adds ? $adds.$j : '';

$selected = $this->have($sid,$id) ? 'selected' : '';

@extract($a);

eval("$nstr = "$str";");

$this->ret .= $nstr;

$this->get_tree_multi($id,$adds.$k.'&nbsp;');

$number++;

}

}

return $this->ret;

}

/**

* @param integer $myid 要查询的ID

* @param string $str   第一种HTML代码方式

* @param string $str2  第二种HTML代码方式

* @param integer $sid  默认选中

* @param integer $adds 前缀

*/

public function get_tree_category($myid,$str2,$id) ? 'selected' : '';

@extract($a);

if (empty($html_disabled)) {

eval("$nstr = "$str";");

} else {

eval("$nstr = "$str2";");

}

$this->ret .= $nstr;

$this->get_tree_category($id,$adds.$k.'&nbsp;');

$number++;

}

}

return $this->ret;

}

/**

* 同上一类方法,jquery treeview 风格,可伸缩样式(需要treeview插件支持)

* @param $myid 表示获得这个ID下的所有子级

* @param $effected_id 需要生成treeview目录数的id

* @param $str 末级样式

* @param $str2 目录级别样式

* @param $showlevel 直接显示层级数,其余为异步显示,0为全部限制

* @param $style 目录样式 默认 filetree 可增加其他样式如'filetree treeview-famfamfam'

* @param $currentlevel 计算当前层级,递归使用 适用改函数时不需要用该参数

* @param $recursion 递归使用 外部调用时为FALSE

*/

    function get_treeview($myid,$effected_id='example',$str="<span class='file'>$name</span>",$str2="<span class='folder'>$name</span>",$showlevel = 0,$filetree ',$currentlevel = 1,$recursion=FALSE) {

        $child = $this->get_child($myid);

        if(!defined('EFFECTED_INIT')){

           $effected = ' id="'.$effected_id.'"';

           define('EFFECTED_INIT',1);

        } else {

           $effected = '';

        }

$placeholder = '<ul><li><span class="placeholder"></span></li></ul>';

        if(!$recursion) $this->str .='<ul'.$effected.'  class="'.$style.'">';

        foreach($child as $id=>$a) {

        @extract($a);

if($showlevel > 0 && $showlevel == $currentlevel && $this->get_child($id)) $folder = 'hasChildren'; //如设置显示层级模式@2011.07.01

        $floder_status = isset($folder) ? ' class="'.$folder.'"' : '';

            $this->str .= $recursion ? '<ul><li'.$floder_status.' id=''.$id.''>' : '<li'.$floder_status.' id=''.$id.''>';

            $recursion = FALSE;

            if($this->get_child($id)){

            eval("$nstr = "$str2";");

            $this->str .= $nstr;

                if($showlevel == 0 || ($showlevel > 0 && $showlevel > $currentlevel)) {

$this->get_treeview($id,$effected_id,$showlevel,$style,$currentlevel+1,TRUE);

} elseif($showlevel > 0 && $showlevel == $currentlevel) {

$this->str .= $placeholder;

}

            } else {

                eval("$nstr = "$str";");

                $this->str .= $nstr;

            }

            $this->str .=$recursion ? '</li></ul>': '</li>';

        }

        if(!$recursion)  $this->str .='</ul>';

        return $this->str;

    }

/**

* 获取子栏目json

* Enter description here ...

* @param unknown_type $myid

*/

public function creat_sub_json($myid,$str='') {

$sub_cats = $this->get_child($myid);

$n = 0;

if(is_array($sub_cats)) foreach($sub_cats as $c) {

$data[$n]['id'] = iconv(CHARSET,'utf-8',$c['catid']);

if($this->get_child($c['catid'])) {

$data[$n]['liclass'] = 'hasChildren';

$data[$n]['children'] = array(array('text'=>'&nbsp;','classes'=>'placeholder'));

$data[$n]['classes'] = 'folder';

$data[$n]['text'] = iconv(CHARSET,$c['catname']);

} else {

if($str) {

@extract(array_iconv($c,CHARSET,'utf-8'));

eval("$data[$n]['text'] = "$str";");

} else {

$data[$n]['text'] = iconv(CHARSET,$c['catname']);

}

}

$n++;

}

return json_encode($data);

}

private function have($list,$item){

return(strpos(','.$list.',','.$item.','));

}

}

/**

 * +------------------------------------------------

 * 格式化数组

 * +------------------------------------------------

 */

function getArray($myid = 0,$adds = '') {

    $number = 1;

    $child = $this->get_child($myid);

    if (is_array($child)) {

        $total = count($child);

        foreach ($child as $id => $a) {

            $j = $k = '';

            if ($number == $total) {

                $j .= $this->icon[2];

            } else {

                $j .= $this->icon[1];

                $k = $adds ? $this->icon[0] : '';

            }

            $spacer = $adds ? $adds . $j : '';

            @extract($a);

            $a[$name] = $spacer . $a[$name];

            $this->ret[$a[$id]] = $a;

            $fd = $adds . $k . $this->nbsp;

            $this->getArray($id,$fd);

            $number++;

        }

    }

    return $this->ret;

}

?>

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


极简概括: PHP 的开源内存缓存扩展,类比Redis,但是一般都用Redis,所以APCu用的很少。官方文档:https://www.php.net/manual/zh/apcu.configuration.php解决问题:类比Redis做缓存组件,提升性能,同步数据使用。
请看如下代码: $list = [1,2,4,5]; $list2 = [5,6,7,9]; foreach ($list as $key =&gt; &amp;$value) { $value = strval($value); } foreach ($list2 as $key =&gt; $v
一、nginx 安装 1. 在nginx官网下载nginx源码&#x9;提供一个nginx官网下载地址: http://nginx.org/download/nginx-1.12.2.tar.gz 注意:请先确认 是否已经安装过 pcre pcre-devel openssl openssl-devel z
先看图 数据条数:9000+ 第1,2行,golangʾxcelize方式导出,耗时:5s 第3行,PHP+xlswriter方式导出,耗时:2min 一、介绍 xlswriter是一个高效处理excel文件的PHP扩展,底层以C语言实现;处理速度是PHPExcel几十倍甚至几百倍的效率。 官方链
今天使用Thinkphp5做异步任务传递where参数时遇到一个问题: 有一段如下代码: $where[&#39;jst.supplier&#39;] = [&#39;exp&#39;, Db::raw(&#39;&gt;0 or jst.is_supplier=1&#39;)]; 在使用swool
汇总 PHP5.1: autoload PDO MySQLi 类型约束 PHP5.2: JSON 支持 PHP5.3: 命名空间 匿名函数 闭包 新增魔术方法__callStatic()和__invoke() 新增魔术变量__DIR__ 动态调用静态方法 延迟静态绑定 Heredoc和 Nowdoc
文章浏览阅读8.4k次,点赞8次,收藏7次。SourceCodester Online Tours & Travels Management System pay.php sql injectionLine 16 of pay.php invokes a SQL query built using unvalidated input. This call could allow an attacker to modify the statement’s meaning or to execute arbitrary SQL commands.SQL
文章浏览阅读3.4k次,点赞46次,收藏51次。本文为大家介绍在windwos系统搭建typecho博客+cpolar内网穿透工具将博客发布到公共网络环境,实现远程也可以访问和操作。_windows搭建typecho
文章浏览阅读1.1k次。- php是最优秀, 最原生的模板语言, 替代语法,让php更加的优雅的与html生活在一起 -->请放心, 最终生成的,或者说用户最终看到的,仍然是一个html文档, php代码中的内容不会被泄漏的。-- 将php与html代码混编的时候,大括号很容易造成配对错误,最好杜绝它 -->php标签内部代码由php.exe解释, php标签之外的代码原样输出,仍由web服务器解析。-- 所以php的流程控制语句, 都提供了替代语法,用冒号代替大括号 -->php echo '百变鹏仔'?_利用php将静态页面修改为动态页面
文章浏览阅读1.1k次,点赞18次,收藏15次。整理K8s网络相关笔记博文内容涉及 Linux network namespace 认知以及彼此通信Demo,实际中的应用理解不足小伙伴帮忙指正不必太纠结于当下,也不必太忧虑未来,当你经历过一些事情的时候,眼前的风景已经和从前不一样了。——村上春树。_linux network namespace 多端通信 模式认知
文章浏览阅读1.2k次,点赞22次,收藏19次。此网络模型提供了一个逻辑二层(L2)网络,该网络封装在跨 Kubernetes 集群节点的现有三层(L3)网络拓扑上。使用此模型,可以为容器提供一个隔离的 L2 网络,而无需分发路由。封装网络带来了少量的处理开销以及由于覆盖封装生成 IP header 造成的 IP 包大小增加。封装信息由 Kubernetes worker 之间的 UDP 端口分发,交换如何访问 MAC 地址的网络控制平面信息。此类网络模型中常用的封装是 VXLAN、Internet 协议安全性 (IPSec) 和 IP-in-IP。_k8s网络组件对比
文章浏览阅读1.1k次,点赞14次,收藏19次。当我们谈论网络安全时,我们正在讨论的是保护我们的在线空间,这是我们所有人的共享责任。网络安全涉及保护我们的信息,防止被未经授权的人访问、披露、破坏或修改。
文章浏览阅读1.3w次,点赞3次,收藏7次。尽管您可以通过 ping 命令解析出网站的 IP 地址,但是可能在浏览器中访问时仍然遇到问题,这可能是因为浏览器使用的 DNS 解析结果不同于 ping 命令使用的解析结果。可能是因为您的网络或设备上设置了防火墙,阻止了对特定网站的访问。有些国家或组织可能会对特定的域名进行屏蔽,从而阻止访问相关网站。如果您的网络使用代理服务器进行访问控制,可能会由于代理服务器的配置问题导致无法访问某些网站。即使您的网络和设备一切正常,目标网站本身可能也存在问题,例如服务器故障、维护或过载,导致无法访问。_能ping通打不开网页
文章浏览阅读839次,点赞22次,收藏19次。本系统带文档lw万字以上文末可领取本课题的JAVA源码参考。
文章浏览阅读2.1k次,点赞31次,收藏22次。基于微信小程序奶茶点餐外卖系统设计与实现(PHP后台+Mysql)可行性分析毕设源代码毕业设计,数据安全和系统稳定性以及团队能力和资源配备方面都具备较好的条件。因此,该项目的可行性较高。:黄菊华老师《Vue.js入门与商城开发实战》《微信小程序商城开发》图书作者,CSDN博客专家,在线教育专家,CSDN钻石讲师;微信小程序作为一种快捷、方便的移动应用形式,成为很多用户点餐外卖的首选。项目的界面和功能都可以定制,包安装运行!项目配有对应开发文档、开题报告、任务书、PPT、论文模版等。
文章浏览阅读1.8k次,点赞52次,收藏38次。本文主要通过对系统的前台系统和后台管理系统进行了功能性需求分析,对系统的安全性和可扩展性进行了非功能性需求分析。在详细的需求分析的基础上,根据系统的功能设计确定了数据库结构,实现完整的代码编写。Lucky+Baby母婴用品网站使用 Dreamweaver、HBuilder代码编辑器、Apache服务器等开发工具,完成了系统的主要模块的页面设计和功能实现。本文展示了首页页面的实现效果图,并通过代码和页面介绍了用户注册功能、商品搜索功能、生成订单和查看我的订单功能、在线付款功能功能的实现过程。
文章浏览阅读1.5k次,点赞45次,收藏40次。本设计主要实现集人性化、高效率、便捷等优点于一身的人事信息管理系统,完成首页、系统用户、通知公告、部门信息、员工薪资、考勤签到、员工请假、招聘信息、应聘信息等功能模块。
文章浏览阅读1k次。该错误通常出现在数据库读取结果集数据时,比如当我们写好SQL语句从数据库读取数据时,本身应该返回结果集,再给结果集中读取数据。解决思路:这种错误一般是因为echo后面输出了一个数组导致的,或者是数组作为字符串进行拼接运算时导致的。该错误直译为:警告:mysqli_fetch_assoc函数期望参数1是mysqli的结果集,但是给了一个布尔值。这种错误是PHP解析器在解析时遇到了语法错误,直译为:解析错误:语法错误,意料之外的...该错误直译为:提示:未定义的索引:username。_array to string conversion in
文章浏览阅读2.7w次。解决http请求报错context deadline exceeded (Client.Timeout exceeded while awaiting headers)_context deadline exceeded (client.timeout exceeded while awaiting headers)
文章浏览阅读1.3k次,点赞26次,收藏24次。复杂网络是一种由大量相互连接的元素(节点或顶点)组成的网络结构,这些连接通常是非常复杂和动态的。这些网络可以在各种领域中发现,包括社交网络、生物学系统、信息技术和交通系统等。_代理建模