PHP는 데이터의 계층적 트리 표시를 재귀적으로 구현합니다. 여러분의 의견을 듣고 제가 어떻게 작성하는지 살펴보시기 바랍니다.
먼저 데이터 테이블을 만들고 데이터를 추가하세요
CREATE TABLE IF NOT EXISTS category ( categoryId smallint(5) unsigned NOT NULL AUTO_INCREMENT, parentId smallint(5) unsigned NOT NULL DEFAULT '0', categoryName varchar(50) NOT NULL, PRIMARY KEY (categoryId) ) ; INSERT INTO category (categoryId, parentId, categoryName) VALUES (1, 0, 'php'), (2, 0, 'java'), (3, 0, 'c/c++'), (4, 1, 'php基础'), (5, 1, 'php开源资料'), (6, 1, 'php框架'), (7, 2, 'java Se'), (8, 2, 'java EE'), (9, 2, 'java Me'), (10, 3, 'c/c++基础编程'), (11, 3, 'c/c++系统开发'), (12, 3, 'c嵌入式编程'), (13, 3, 'c++应用开发'), (14, 13, 'c++桌面应用开发'), (15, 13, 'c++游戏开发');
<code>/** *递归实现层级树状展现数据 *$tree为二位数组, *$depth为树的最大深度,0表示不设置深度 *$rootId表示父级分类的ID *$level记录层级树的层数 **/ function arr2tree($tree,$depth,$rootId = 0,$level=1) { $return = array(); foreach($tree as $leaf) { if($leaf['parentId'] == $rootId) { $leaf['level'] = $level; foreach($tree as $subleaf) { if($subleaf['parentId'] == $leaf['categoryId'] && ($depth?$level<$depth:1)) { $leaf['children'] = arr2tree($tree,$depth,$leaf['categoryId'],$level+1); $level=1; break; } } $return[] = $leaf; } } return $return; } $tree = arr2tree($category,0); $tree1 = arr2tree($category,2); echo "<pre class="brush:php;toolbar:false">"; print_r($tree); print_r($tree1);</code>
답글 내용:
먼저 데이터 테이블을 만들고 데이터를 추가하세요
CREATE TABLE IF NOT EXISTS category ( categoryId smallint(5) unsigned NOT NULL AUTO_INCREMENT, parentId smallint(5) unsigned NOT NULL DEFAULT '0', categoryName varchar(50) NOT NULL, PRIMARY KEY (categoryId) ) ; INSERT INTO category (categoryId, parentId, categoryName) VALUES (1, 0, 'php'), (2, 0, 'java'), (3, 0, 'c/c++'), (4, 1, 'php基础'), (5, 1, 'php开源资料'), (6, 1, 'php框架'), (7, 2, 'java Se'), (8, 2, 'java EE'), (9, 2, 'java Me'), (10, 3, 'c/c++基础编程'), (11, 3, 'c/c++系统开发'), (12, 3, 'c嵌入式编程'), (13, 3, 'c++应用开发'), (14, 13, 'c++桌面应用开发'), (15, 13, 'c++游戏开发');
<code>/** *递归实现层级树状展现数据 *$tree为二位数组, *$depth为树的最大深度,0表示不设置深度 *$rootId表示父级分类的ID *$level记录层级树的层数 **/ function arr2tree($tree,$depth,$rootId = 0,$level=1) { $return = array(); foreach($tree as $leaf) { if($leaf['parentId'] == $rootId) { $leaf['level'] = $level; foreach($tree as $subleaf) { if($subleaf['parentId'] == $leaf['categoryId'] && ($depth?$level<$depth:1)) { $leaf['children'] = arr2tree($tree,$depth,$leaf['categoryId'],$level+1); $level=1; break; } } $return[] = $leaf; } } return $return; } $tree = arr2tree($category,0); $tree1 = arr2tree($category,2); echo "<pre class="brush:php;toolbar:false">"; print_r($tree); print_r($tree1);</code>
http://stackoverflow.com/questions/4196157/create-array-tree-from-array-list

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











이번 장에서는 CakePHP의 환경 변수, 일반 구성, 데이터베이스 구성, 이메일 구성에 대해 알아봅니다.

PHP 8.4는 상당한 양의 기능 중단 및 제거를 통해 몇 가지 새로운 기능, 보안 개선 및 성능 개선을 제공합니다. 이 가이드에서는 Ubuntu, Debian 또는 해당 파생 제품에서 PHP 8.4를 설치하거나 PHP 8.4로 업그레이드하는 방법을 설명합니다.

CakePHP는 PHP용 오픈 소스 프레임워크입니다. 이는 애플리케이션을 훨씬 쉽게 개발, 배포 및 유지 관리할 수 있도록 하기 위한 것입니다. CakePHP는 강력하고 이해하기 쉬운 MVC와 유사한 아키텍처를 기반으로 합니다. 모델, 뷰 및 컨트롤러 gu

VS Code라고도 알려진 Visual Studio Code는 모든 주요 운영 체제에서 사용할 수 있는 무료 소스 코드 편집기 또는 통합 개발 환경(IDE)입니다. 다양한 프로그래밍 언어에 대한 대규모 확장 모음을 통해 VS Code는
