getAll($sql); $g_db->close ();$list=roletree($roles,0);//Appeler la fonction selon l'identifiant du parent"/> getAll($sql); $g_db->close ();$list=roletree($roles,0);//Appeler la fonction selon l'identifiant du parent">
Maison >développement back-end >tutoriel php >Introduction aux méthodes de classification et de tri Infinitus
D'abord, la table de données est similaire à celle-ci, puis effectuez une requête de données pour obtenir toutes les données
$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]['ar_name'] = str_repeat('----',$v['ar_level']).$v['ar_name'].'<br>'; } //将角色经排序 function roletree($arr,$id=0) { $subs = array(); // 子孙数组 foreach($arr as $v) { if($v['ar_parent_id'] == $id) { $subs[] = $v; $subs = array_merge($subs,roletree($arr,$v['ar_id'])); } } return $subs; }
Ensuite, elle est sortie en boucle sur la page statique, l'effet est le suivant :
Celui qui ajoute un subordonné à l'effet d'affichage sera à côté de ce subordonné
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!