<?php
header("Content-Type: text/html; charset=UTF-8");
Class Category {
//組合一維數組(拼成等級形狀) 明確標出每個類別的等級,一維
Static Public function unlimitedForLevel ($cate, $html = '-|', $pid = 0, $level = 1) {
$arr = array();
foreach ($cate as $k => $v) {
if ($v['pid'] == $pid) {
$v['level'] = $level;
$v['html'] = str_repeat($html, $level);
$arr[] = $v;
$arr = array_merge($arr, self::unlimitedForLevel($cate, $html, $v['id'], $level + 1));
}
}
return $arr;
}
//組合多維數組 一個總類別下的其他類別,多維
Static Public function unlimitedForLayer ($cate, $name = 'child', $pid = 0) {
$arr = array();
foreach ($cate as $v) {
if ($v['pid'] == $pid) {
if(!empty(self::unlimitedForLayer($cate, $name, $v['id']))){
$v[$name] = self::unlimitedForLayer($cate, $name, $v['id']);
}
$arr[] = $v;
}
}
return $arr;
}
//傳遞一個子分類ID返回所有的父級分類Id
Static Public function getParentsId($cate, $id) {
$arr = array();
foreach ($cate as $v) {
if ($v['id'] == $id) {
if($v['pid'] != 0){
$arr[] = $v['pid'];
$arr = array_merge(self::getParentsId($cate, $v['pid']), $arr);
}
}
}
return $arr;
}
//傳遞一個子分類ID返回所有的父級分類信息 有瑕疵,包含了當前子分類的信息
//根據位置,刪除后 使用
Static Public function getParents($cate, $id) {
$arr = array();
foreach ($cate as $v) {
if ($v['id'] == $id) {
$arr[] = $v;
if($v['pid'] != 0){
$arr = array_merge(self::getParents($cate, $v['pid']),$arr);
}
}
}
return $arr;
}
//傳遞一個父級分類ID返回所有子分類ID
Static Public function getChildsId ($cate, $pid) {
$arr = array();
foreach ($cate as $v) {
if ($v['pid'] == $pid) {
$arr[] = $v['id'];
$arr = array_merge($arr, self::getChildsId($cate, $v['id']));
}
}
return $arr;
}
//傳遞一個父級分類ID返回所有子分類信息
Static Public function getChilds ($cate, $pid) {
$arr = array();
foreach ($cate as $v) {
if ($v['pid'] == $pid) {
$arr[] = $v;
$arr = array_merge($arr, self::getChilds($cate, $v['id']));
}
}
return $arr;
}
public static function test(){
$arr = [
['id'=>1,'name'=>'zjx'],
['id'=>2,'name'=>'xml'],
['id'=>3,'name'=>'hhh'],
];
array_pop($arr);
return $arr;
}
}
$cate = array(
0 => array('id' => 1, 'pid' => 0, 'name' => '中國'),
1 => array('id' => 2, 'pid' => 1, 'name' => '河北省'),
2 => array('id' => 3, 'pid' => 1, 'name' => '山西省'),
3 => array('id' => 4, 'pid' => 3, 'name' => '大同市'),
4 => array('id' => 5, 'pid' => 2, 'name' => '張家口市'),
5 => array('id' => 6, 'pid' => 5, 'name' => '包頭'),
6 => array('id' => 7, 'pid' => 6, 'name' => '張家村'),
7 => array('id' => 8, 'pid' => 4, 'name' => '天鎮縣'),
);
//print_r(Category::unlimitedForLevel($cate));
//var_dump(Category::unlimitedForLayer($cate));
$arr = Category::getParents($cate,8);
array_pop($arr);
var_dump($arr);
//var_dump(Category::getParentsId($cate,7));
//var_dump(Category::getChildsId($cate,2));
//var_dump(Category::getChilds($cate,2));
//var_dump(Category::test());
?>
遞歸無限極分類
最后編輯于 :
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
- 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
- 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
- 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
推薦閱讀更多精彩內容
- 在平時工作中, 經常需要將普通列表數據, 處理成樹, 列表數據結構大致如下: 常規實現方式是使用遞歸模式, 但是在...
- SQL Server 2005開始,我們可以直接通過CTE來支持遞歸查詢,CTE即公用表表達式 百度百科公用表表達...
- 第一步、創建數據庫 數據表創建直接復制到mysql管理器里直接運行即可。 DROP TABLE IF EXISTS...