开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

查看: 796|回复: 5
收起左侧

[已解决] 求一个php递归代码,有一段数据不知道怎么生成

 关闭 [复制链接]
结帖率:99% (152/153)
发表于 2022-11-2 01:31:09 | 显示全部楼层 |阅读模式   广东省江门市
100精币
数据库内有数据如下:

1.png


父id为0的是顶级菜单,父id不为0的则是某个顶级菜单下的子菜单,请教下如何用递归来生成一段JSON文本呢,预期效果如下:


2.png


想了几个小时愣是没想通,有没有大牛帮忙给个demo思路,感谢


[PHP] 纯文本查看 复制代码
[
  {
    "id": 1,
    "name": "菜单1",
    "sub_list": [
      {
        "id": 4,
        "name": "菜单4"
      },
      {
        "id": 5,
        "name": "菜单5"
      }
    ]
  },
  {
    "id": 2,
    "name": "菜单2",
    "sub_list": [
      {
        "id": 6,
        "name": "菜单6"
      },
      {
        "id": 7,
        "name": "菜单7"
      }
    ]
  },
  {
    "id": 3,
    "name": "菜单3",
    "sub_list": [
      {
        "id": 8,
        "name": "菜单8"
      },
      {
        "id": 9,
        "name": "菜单9",
        "sub_list": [
          {
            "id": 10,
            "name": "菜单10"
          }
        ]
      }
    ]
  }
]

最佳答案

查看完整内容

大致 就是这样,没验证,你可以试试 [mw_shl_code=php,true]function RecursionQuery($fid = 0){ // 通过父id cha询数据库。 $list = query($fid); // 循环cha询到的子项目 foreach($list as $item) { // 递归cha询 $sub_list = RecursionQuery($item['id']); // 如果cha询到的子项目大于0 增加 sub_list 键 if(count($sub_list) > 0) { $item['sub_list' ...

回答提醒:如果本帖被关闭无法回复,您有更好的答案帮助楼主解决,请发表至 源码区 可获得加分喔。
友情提醒:本版被采纳的主题可在 申请荣誉值 页面申请荣誉值,获得 1点 荣誉值,荣誉值可兑换荣誉会员、终身vip用户组。
快捷通道:申请荣誉值无答案申请取消悬赏投诉有答案未采纳为最佳

结帖率:100% (4/4)

签到天数: 2 天

发表于 2022-11-2 01:31:10 | 显示全部楼层   安徽省芜湖市
大致 就是这样,没验证,你可以试试

[PHP] 纯文本查看 复制代码
function RecursionQuery($fid = 0){
    // 通过父id cha询数据库。
    $list = query($fid);

    // 循环cha询到的子项目
    foreach($list as $item) {
        // 递归cha询
        $sub_list = RecursionQuery($item['id']);
        
        // 如果cha询到的子项目大于0 增加 sub_list 键
        if(count($sub_list) > 0) {
            $item['sub_list'] = $sub_list;
        }
    }
    
    return $list;
}

$list = RecursionQuery(0);


评分

参与人数 1荣誉 +1 收起 理由
笨潴 + 1 热心帮助他人,荣誉+1,希望继续努力(*^__^*) 嘻嘻!

查看全部评分

回复

使用道具 举报

结帖率:100% (1/1)

签到天数: 21 天

发表于 2022-11-2 02:09:09 | 显示全部楼层   浙江省宁波市
json.置属性("id",1)
json.置属性("name",”菜单1”)
......
然后json.取数据文本()
回复

使用道具 举报

结帖率:99% (152/153)

签到天数: 13 天

 楼主| 发表于 2022-11-2 02:17:42 | 显示全部楼层   广东省江门市
无量科技 发表于 2022-11-2 02:09
json.置属性("id",1)
json.置属性("name",”菜单1”)
......

兄弟你没明白,我想弄的是递归。你再看看
回复

使用道具 举报

签到天数: 19 天

发表于 2022-11-2 08:30:02 | 显示全部楼层   河南省周口市
先cha询父id为0的记录,然后循环这些记录去读取父id等于这些id的 记录 然后在json_encode就行了 。php数组转json太方便了。果然是地球上最好的语言。

评分

参与人数 1好评 +1 精币 +1 收起 理由
㠫孬嫑夯芘 + 1 + 1 很赞同,谢谢!

查看全部评分

回复

使用道具 举报

结帖率:93% (66/71)

签到天数: 2 天

发表于 2022-11-2 13:11:30 | 显示全部楼层   福建省宁德市
好小子,2014年 回答的问题,今天才给我采纳。
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则 致发广告者

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 诚聘英才| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报电话0663-3422125,QQ: 800073686,邮箱:800073686@b.qq.com
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备12094385号-1) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

快速回复 返回顶部 返回列表