getAll($sql);$g_db->close ();$list=roletree($roles,0);//呼叫函數以父級id進行"/> getAll($sql);$g_db->close ();$list=roletree($roles,0);//呼叫函數以父級id進行">

首頁 >後端開發 >php教程 >無限極分類且排序的方法介紹

無限極分類且排序的方法介紹

巴扎黑
巴扎黑原創
2017-07-18 17:27:561305瀏覽

首先資料表類似於這樣,然後進行資料查詢取得所有的資料

 

#
$sql   ="select * from ec_admin_role  where ar_state=1 order by ar_level";
$roles = $g_db->getAll($sql);
$g_db->close();
$list=roletree($roles,0);//调用函数按父级id进行排序
foreach($list as $k=>$v) {
$list[$k][&#39;ar_name&#39;] = str_repeat(&#39;----&#39;,$v[&#39;ar_level&#39;]).$v[&#39;ar_name&#39;].&#39;<br>&#39;;
}


//将角色经排序
function roletree($arr,$id=0) {
    $subs = array(); // 子孙数组
    foreach($arr as $v) {
        if($v[&#39;ar_parent_id&#39;] == $id) {
            $subs[] = $v;
            $subs = array_merge($subs,roletree($arr,$v[&#39;ar_id&#39;]));
        }
    }
    return $subs;
}

  然後在靜態頁面中循環輸出,效果如下:

顯示效果誰加入下級,那個下級就緊鄰誰

 

#

以上是無限極分類且排序的方法介紹的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
上一篇:霍納法則下一篇:霍納法則