PHPTree - PHP는 무제한 분류_php 기술을 빠르게 생성합니다.

不言
풀어 주다: 2023-03-23 07:58:02
원래의
4422명이 탐색했습니다.

트리 데이터는 전형적인 트리 구조인 무한 다단계 분류 등 개발에 자주 사용됩니다. 여기서 알고리즘은 재귀적 사고를 사용하여 개발 프로세스를 단순화하기 위해 개발 효율성을 향상시키는 도구를 작성했습니다. 도움이 필요한 친구들이 참고할 수 있습니다

PHPTree입니다.

git 주소: https://git.oschina.net/jiusem/PHPTree.git

또는 스크립트 홈 http://www.jb51.net/codes/606002.html

가장 간단한 예:

<?php 
require(&#39;PHPTree.class.php&#39;);

//原始数据, 从数据库读出
$data = array(
	array(
		&#39;id&#39;=>1,
		&#39;name&#39;=>&#39;book&#39;,
		&#39;parent_id&#39;=>0
	),
	array(
		&#39;id&#39;=>2,
		&#39;name&#39;=>&#39;music&#39;,
		&#39;parent_id&#39;=>0
	),
	array(
		&#39;id&#39;=>3,
		&#39;name&#39;=>&#39;book1&#39;,
		&#39;parent_id&#39;=>1
	),
	array(
		&#39;id&#39;=>4,
		&#39;name&#39;=>&#39;book2&#39;,
		&#39;parent_id&#39;=>3
	)
);

$r = PHPTree::makeTree($data);
echo json_encode($r);

?>
로그인 후 복사

출력:

[
                                                                                  0,
"expanded": false, //하위 노드를 확장하지 않습니다.                                  'parent_id': 1,
"" "expanded": false ,
" "children": [
" " " "id ": 4,
" name ":" book2 ",
" Parent_id ": 3,
" leaf ": true
}
]}
]},
{

" "" ": "music",
"parent_id": 0,
"leaf": true
"" }
]



생성된 데이터는 트리 구조이며, ExtJS와 같은 프론트엔드 프레임워크. Git에는 참조할 수 있는 ExtJS 데모가 포함되어 있습니다.

Demo:




프론트 엔드 프레임워크를 사용할 필요가 없고 HTML로 출력만 하는 경우 다음 방법을 사용할 수 있습니다.

$r = PHPTree::makeTreeForHtml($data);

1차원 배열을 가져오고, 레벨 필드를 사용하여 분류 수준을 식별합니다.

array(
 array(
  &#39;id&#39;=>1,
  &#39;name&#39;=>&#39;用户管理&#39;,
  &#39;parent_id&#39;=>0,
  &#39;level&#39;=>0 //一级分类
 ),
 array(
  &#39;id&#39;=>1,
  &#39;name&#39;=>&#39;用户列表&#39;,
  &#39;parent_id&#39;=>1,
  &#39;level&#39;=>1 //二级分类
 )
 ....
);
로그인 후 복사

선택 태그로 출력:

echo &#39;<h1>PHPTree树形结构</h1>&#39;;
echo &#39;<select style="width:300px;">&#39;;
foreach($r as $item){
	echo &#39;<option>&#39;;
	//根据所在的层次缩进
	echo str_repeat(&#39;......&#39;,$item[&#39;level&#39;]);
	echo $item[&#39;name&#39;];
	echo &#39;</option>&#39;;
}
echo &#39;</select>&#39;;
로그인 후 복사

데모:

Git에는 HTML을 출력하는 데모를 참고하시면 됩니다.

데이터베이스 설계와 관련하여 id 및 parent_id 필드만 포함되어 있는지 확인하면 됩니다. 다른 필드는 데이터 생성에 영향을 주지 않고 직접 추가할 수 있습니다. parent_id는 상위 ID입니다. 1차 분류인 경우 0으로 설정하세요. 물론 필드도 구성할 수 있습니다. 계속 읽어주세요. 몇 가지 고급 사용 방법을 소개하겠습니다.

하위 노드 확장:

PHPTree::makeTree( $data, array(
 &#39;expanded&#39; => true
));
로그인 후 복사

输出的数据为:

[
{
id:1,
name:'book1',
expanded:true,//展开子节点
children:[
...
]
}
]

自定义主键和父键:

//数据库读出
$data = array(
 array(
  &#39;order_id&#39;=>1, //主键
  &#39;name&#39;=>&#39;book1&#39;,
  &#39;pid&#39;=>0, //父键
  ...
 )
);
PHPTree::makeTree( $data, array(
 &#39;primary_key&#39; => &#39;order_id&#39;,
 &#39;parent_key&#39; => &#39;pid&#39;
));
로그인 후 복사

输出的数据为:

[
{
order_id:1,
name:'book1',
pid:0,
...
}
]

makeTreeForHtml 方法也支持配置主键和父键。

还有其他字段也可以自定义,但下面这些参数仅支持 makeTree 方法:

$r = PHPTree::makeTree($data, array(
 &#39;expanded_key&#39; => &#39;expanded&#39;,
 &#39;children_key&#39; => &#39;children&#39;,
 &#39;leaf_key&#39;  => &#39;leaf&#39;
));
로그인 후 복사

默认,这些字段的配置都是以ExtJS为参考的,如果你使用zTree框架的话,这些字段就需要重新配置了。

zTree 是一款强大的国产树形框架,它还支持 简单JSON格式,是一维数据格式,实际上就不需要用到PHPTree了。当然,PHPTree输出的数据层次感清晰,zTree也是支持的。

相关推荐:

php递归实现无限级分类的开发过程及示例代码

php 实现无限级分类的三种方式

php无限级分类实现方法分析

위 내용은 PHPTree - PHP는 무제한 분류_php 기술을 빠르게 생성합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!