四虎精品视频-四虎精品成人免费网站-四虎黄色网-四虎国产视频-国产免费91-国产蜜臀97一区二区三区

php 無限級分類學習參考之對ecshop無限級分類的解析 帶詳細注釋

復制代碼 代碼如下:
function cat_options($spec_cat_id, $arr)
{
static $cat_options = array();
if (isset($cat_options[$spec_cat_id]))
{
return $cat_options[$spec_cat_id];
}
/*
初始化關鍵參數:
$level:當前子節點深度
$last_cat_id:當前父節點ID
$options:帶有縮進級別的數組
$cat_id_array:沿同一路徑的父節點依次進駐
$level_array:該節點的子節點深度,也是依次進駐
*/
if (!isset($cat_options[0]))
{
$level = $last_cat_id = 0;
$options = $cat_id_array = $level_array = array();
while (!empty($arr))//如果還有待構造的節點則繼續遍歷
{
foreach ($arr AS $key => $value)
{
$cat_id = $value['cat_id'];
//一級分類結點
if ($level == 0 && $last_cat_id == 0)
{
if ($value['parent_id'] > 0)
{
break;
}
$options[$cat_id] = $value;
$options[$cat_id]['level'] = $level;
$options[$cat_id]['id'] = $cat_id;
$options[$cat_id]['name'] = $value['cat_name'];
//遍歷過了就不再遍歷
unset($arr[$key]);
if ($value['has_children'] == 0)
{
continue;
}
$last_cat_id = $cat_id;//下層結點的父親結點
$cat_id_array = array($cat_id);
$level_array[$last_cat_id] = ++$level;
continue;
}
//當前結點的父親結點ID等于它的上一級結點ID
if ($value['parent_id'] == $last_cat_id)
{
$options[$cat_id] = $value;
$options[$cat_id]['level'] = $level;
$options[$cat_id]['id'] = $cat_id;
$options[$cat_id]['name'] = $value['cat_name'];
unset($arr[$key]);//遍歷過了就不再遍歷
//如果當前結點有孩子則當前結點要進駐,但不再遍歷;反之不進駐也不再遍歷
if ($value['has_children'] > 0)
{
if (end($cat_id_array) != $last_cat_id)
{
$cat_id_array[] = $last_cat_id;
}
$last_cat_id = $cat_id;//當現結點做為下一級結點的新的父親結點
$cat_id_array[] = $cat_id;//進駐

$level_array[$last_cat_id] = ++$level;//當前結點的下一級結點深度
}

}
elseif ($value['parent_id'] > $last_cat_id)
{//如果當前結點父親深度大于目前父親結點的深度則進行下一輪循環
break;
}
}//endforeach
$count = count($cat_id_array);
if ($count > 1)
{
//取出最后進駐的父親節點作為當前父親節點
$last_cat_id = array_pop($cat_id_array);
}
elseif ($count == 1)
{
if ($last_cat_id != end($cat_id_array))
{
//進駐的父親結點只有一個時并且沒有作為當前父親節點時把它取出
$last_cat_id = end($cat_id_array);
}
else
{ //否則最后取出的父親結點一定是一級分類結點
$level = 0;
$last_cat_id = 0;
$cat_id_array = array();
continue;
}
}

if ($last_cat_id && isset($level_array[$last_cat_id]))
{
//取出當前結點的深度
$level = $level_array[$last_cat_id];
}
else
{
$level = 0;
}
}//end while,此時已完成非遞歸前序遍歷構造樹的工作,其中$options已保存了從根結點開始的所有結點帶有分層性質的數組
$cat_options[0] = $options;
}
else
{
$options = $cat_options[0];
}
//如果從0開始即取整個樹則直接返回不再處理.
if (!$spec_cat_id)
{
return $options;
}
//否則開始從指定結點截取,以下比較簡單我還是稍微說說吧,要說就說幾個參數含義吧
/*
$spec_cat_id_level:截取結點的深度
$spec_cat_id_array:最終返回的以該結點為根結點的一棵商品分類樹
最終返回的數組是這樣排序的:按父親結點大小,按直接父親結點,按同一父親結點這樣的先根遍歷,具個例子:
一級結點有1,5 二級結點有2,6,7 三級結點有8,9,如果1的直接孩子是2,6而2的直接孩子是8,9;另外
5的直接孩子是7那么最終的數組是這樣排列的1->2->8->9->6->5->7
*/
else
{
if (empty($options[$spec_cat_id]))
{
return array();
}
$spec_cat_id_level = $options[$spec_cat_id]['level'];

foreach ($options AS $key => $value)
{
if ($key != $spec_cat_id)
{
unset($options[$key]);
}
else
{
break;
}
}
$spec_cat_id_array = array();
foreach ($options AS $key => $value)
{
if (($spec_cat_id_level == $value['level'] && $value['cat_id'] != $spec_cat_id) ||
($spec_cat_id_level > $value['level']))
{
break;
}
else
{
$spec_cat_id_array[$key] = $value;
}
}
$cat_options[$spec_cat_id] = $spec_cat_id_array;
return $spec_cat_id_array;
}
}

php技術php 無限級分類學習參考之對ecshop無限級分類的解析 帶詳細注釋,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 白上之黑| 梁祝《引子》简谱| 爱在西元前简谱| 电影后妈| 楼下的女邻居| 二次曝光电影有删减吗| 美国伦理小樱桃1| 茶啊二中王强| 甜姐儿| 最后的武士| 亚纱美| 都市频道在线直播| 永远的紫荆花简谱| 竹内纱里奈全部aⅴ在线看| https://www.douyin.com/| 甜蜜监狱| 二年级最佳家长评语| 张静初吴彦祖演的门徒| 卓别林走路视频| 炊事班的故事演员名单| 必修二英语电子课本外研版| 阴道| 情人电影网| 拨萝卜电视剧视频歌高清在线观看大牛| 爱情与灵药 电影| 十万个为什么读书小报| 毒鲨| 建设工程价款结算暂行办法| 三年片大全电影| 孤岛惊魂| 新爱情乐园| 三年片大全电影| 啥啥| 七年级下册英语书电子版| 在线观看中文字幕视频| 素人片| 颂赞诗歌| 手纹线| cctv16体育节目表今天目表| 岳虹| 宋恩彩为艺术奉献的作品有哪些|