前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >PHP 处理数据为树状结构

PHP 处理数据为树状结构

作者头像
游离于山间之上的Java爱好者
发布2022-12-19 08:58:39
8330
发布2022-12-19 08:58:39
举报
文章被收录于专栏:你我杂志刊

本文已同步发布于个人站点 https://qiucode.cn/article/105 文末点击阅读原文也可到达

1、从数据库获取的数据

2、对查询出来的数据按键值归类

代码语言:javascript
复制
<?php

namespace app\index\controller;
use think\Controller;
use think\Db;

use think\Log;


class Data extends Controller {

    public function getTreeData(){
        $res =  Db::table('table_name')
               ->select();

        $erArr = self::getRepeatValGroup($res,'platform');
        Log::info($erArr);

        $newArr = [];
        foreach($erArr as $erK => $erV){

            $arr1 = [];
            foreach ($erV as $k => $v) {
                $arr1[$v['area']][] = $v;
            }
            $newArr[$erK][]=$arr1;
        }
        return json($newArr);
    }


    //$arr= 一个数组。$keys 是该数组里面的某一个值   该自定义函数主要是对二维数组里面的某一个值进行分组
    public function getRepeatValGroup($arr,$keys)
{
        if(!is_array($arr) || !$keys) {
            return false;
        }
        $temp = array();
        foreach($arr as $key=>$val) {
            $temp[$val[$keys]][] = $val;
        }
        return $temp;
    }

}

3、页面通过ajax请求接口,使用第三方书组件

代码语言:javascript
复制

  $.ajax({
                                type:"get",
                                url:"/index/channels/getPlatform",
                                success:function(data){

                                    let platformArr = []
                                    Object.keys(data).map(platform => {
                                        let areaArr = []

                                        data[platform].forEach(areaKey =>{

                                            //console.log('.........................')
                                            //console.log(areaKey)

                                            Object.keys(areaKey).map(area => {

                                                //console.log('<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<')
                                                ///console.log(area)
                                                //console.log('-------------区域-----------------------')
                                                //console.log(areaKey[area])
                                                let countryArr = []

                                                areaKey[area].forEach(country =>{
                                                    countryArr.push({
                                                        id:country.channel_no,
                                                        active: country.active,
                                                        //parentId:data2[0].area,
                                                        label:country.country
                                                    })
                                                })


                                                areaArr.push({
                                                    label:area,
                                                    children:countryArr
                                                })



                                            })

                                        })

                                        if(platform == 'Amazon'){
                                            platformArr.unshift({
                                                label: 'Amazon',
                                                children:areaArr 
                                            })
                                        }else{
                                            platformArr.push({
                                                label: platform,
                                                children:areaArr
                                            }) 
                                        }

                                    })



                                }
                            })
本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2021-07-04,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 你我杂志刊 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档