0

0

将无限分类格式化为树形结构函数

php中文网

php中文网

发布时间:2016-06-07 11:38:38

|

1387人浏览过

|

来源于php中文网

原创

将无限分类表数据输出为树形结构
/**
     * 功能 获取树形结构   注意:callback和level参数禁止传值
     * @param $model  string      表
     * @param $id     int         当前ID
     * @param $fields string    返回字段  前三个字段分别对应id,父id,名称  至少要包含前三个字段,返回的fullname是格式化的名称,如果表中本来有fullname字段建议做别名
     * @param $condition  max    查询条件  
     * @param $orderby  string    排序
     * @param $self boolean     是否包含当前ID数据
     * @param $onlyson  boolean    是否只返回下级
     * @param $return   string    返回数据类型,ids表示只返回id集合  tree返回树形结构数据
     * @return $datas array        返回的数据
     */
    protected function treeStructure($model='',$id=0,$fields='',$condition='',$orderby='',$self=true,$onlyson=false,$return='tree',$callback=false,$level=0){
                //验证参数类型
                if(!is_string($model) || !is_int($id) || !is_string($fields) || !(is_string($condition) || is_array($condition)) || !is_string($orderby) || !is_bool($self) || !is_bool($onlyson) || !in_array($return,array('ids','tree'))) return array();
        
                //验证参数值
                $fields_arr=explode(',',$fields);
        if(empty($model) || empty($fields) || count($fields_arr)         
        //获取 id,父id,名称对应表中的字段
        foreach ($fields_arr as $k=>$f){
            $f=trim($f);
            $f_arr=explode('as',$f);
            $f_arr[0]=trim($f_arr[0]);
            $f_arr[1]=trim($f_arr[1]);
            $fields_arr[$k]=array('field'=>$f_arr[0],'alias'=>$f_arr[1]);
            if($k==2)break;
        }
        $field_id=$fields_arr[0]['field'];
        $field_pid=$fields_arr[1]['field'];
        $field_name=$fields_arr[2]['field'];
        
        
        $model=strtolower($model);
        
        //查询条件
        if(!empty($condition)){
            if(is_array($condition))$map=$map1=$map2=$condition;
            if(is_string($condition))$map['_string']=$map1['_string']=$map2['_string']=$condition;
        }
        
        
        $map[$field_pid]=$id;
        
        //查询
        if(empty($orderby)){
            $list=M()->table($model)->field($fields)->where($map)->select();
        }else{
            $list=M()->table($model)->field($fields)->where($map)->order($orderby)->select();
        }
        
        $datas=array();
        
        //临时字段变量
        $field_level=to_guid_string('level');
        $field_last=to_guid_string('last');
        $field_son_num=to_guid_string('son_num');
        $field_all_son_num=to_guid_string('all_son_num');
        
        if(!$callback && $self && $id!=0){
            $map1[$field_id]=$id;
            $info=M()->table($model)->field($fields)->where($map1)->find();
            $info[$field_level]=$level;
            $info[$field_last]=1;
            $info[$field_son_num]=count($list);
            $datas[]=$info;
            $level++;
        }
        
        if($onlyson){
            foreach ($list as $k=>$v){
                $v[$field_level]=$level;
                $v[$field_last]=(count($list)-1)==$k?1:0;
                $v[$field_son_num]=0;
                if($level==0)$info[$field_all_son_num]=0;
                $datas[]=$v;
            }
        }else{
            if(count($list)>0){
                foreach ($list as $k=>$v){
                    $v[$field_level]=$level;
                    $v[$field_last]=(count($list)-1)==$k?1:0;
                    $map2[$field_pid]=$v[$field_id];
                    $v[$field_son_num]=M()->table($model)->where($map2)->count();//获取下级数量
                    
                    $next_id=intval($v[$field_id]);
                    $next_level=$level+1;
                    $datasx=$this->treeStructure($model,$next_id,$fields,$condition,$orderby,true,false,$return,true,$next_level);
                    if($level==0){
                        $v[$field_all_son_num]=count($datasx);//获取所有子级数量
                    }
                    $datas[]=$v;
                    if(!empty($datasx)){
                        foreach ($datasx as $v1){
                            $datas[]=$v1;
                        }
                    }
                }
            }
        }
        
        if(!$callback && $self && $id!=0){
            $datas[0][$field_all_son_num]=count($datas)-1;
        }

        if(!$callback){
            $ids=array();
            $all_son_num=0;
            foreach ($datas as $k=>$v){
                $ids[]=$v[$field_id];
                
                if($v[$field_level]==0){
                    $all_son_num=$v[$field_all_son_num];
                    $i=0;
                    $v['fullname']=$v[$field_name];
                }else{
                    $i++;
                    $prev_num=$v[$field_level]-1;
                    if($prev_num>0){
                        $prev_icon_t=$i==$all_son_num?'└ ':'│ ';
                        $prev_icon=str_repeat('    '.$prev_icon_t,$prev_num);
                    }else{
                        $prev_icon='';
                    }
                    $icon=$v[$field_last] && $v[$field_son_num]==0?'    └ ':'    ├ ';
                    $v['fullname']=$prev_icon.$icon.$v[$field_name];
                }
                unset($v[$field_level],$v[$field_last],$v[$field_son_num]);
                if(isset($v[$field_all_son_num]))unset($v[$field_all_son_num]);
                $datas[$k]=$v;
            }
            
            if($return=='ids'){
                return $ids;
            }else{
                return $datas;
            }
        }else{
            return $datas;
        }
        
    }
列表效果
将无限分类格式化为树形结构函数

下拉框效果
将无限分类格式化为树形结构函数

AD:真正免费,域名+虚机+企业邮箱=0元

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
C++ 设计模式与软件架构
C++ 设计模式与软件架构

本专题深入讲解 C++ 中的常见设计模式与架构优化,包括单例模式、工厂模式、观察者模式、策略模式、命令模式等,结合实际案例展示如何在 C++ 项目中应用这些模式提升代码可维护性与扩展性。通过案例分析,帮助开发者掌握 如何运用设计模式构建高质量的软件架构,提升系统的灵活性与可扩展性。

14

2026.01.30

c++ 字符串格式化
c++ 字符串格式化

本专题整合了c++字符串格式化用法、输出技巧、实践等等内容,阅读专题下面的文章了解更多详细内容。

9

2026.01.30

java 字符串格式化
java 字符串格式化

本专题整合了java如何进行字符串格式化相关教程、使用解析、方法详解等等内容。阅读专题下面的文章了解更多详细教程。

12

2026.01.30

python 字符串格式化
python 字符串格式化

本专题整合了python字符串格式化教程、实践、方法、进阶等等相关内容,阅读专题下面的文章了解更多详细操作。

4

2026.01.30

java入门学习合集
java入门学习合集

本专题整合了java入门学习指南、初学者项目实战、入门到精通等等内容,阅读专题下面的文章了解更多详细学习方法。

20

2026.01.29

java配置环境变量教程合集
java配置环境变量教程合集

本专题整合了java配置环境变量设置、步骤、安装jdk、避免冲突等等相关内容,阅读专题下面的文章了解更多详细操作。

18

2026.01.29

java成品学习网站推荐大全
java成品学习网站推荐大全

本专题整合了java成品网站、在线成品网站源码、源码入口等等相关内容,阅读专题下面的文章了解更多详细推荐内容。

19

2026.01.29

Java字符串处理使用教程合集
Java字符串处理使用教程合集

本专题整合了Java字符串截取、处理、使用、实战等等教程内容,阅读专题下面的文章了解详细操作教程。

3

2026.01.29

Java空对象相关教程合集
Java空对象相关教程合集

本专题整合了Java空对象相关教程,阅读专题下面的文章了解更多详细内容。

6

2026.01.29

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Git 教程
Git 教程

共21课时 | 3.2万人学习

Kotlin 教程
Kotlin 教程

共23课时 | 3万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号