Jag ser ett problem med din lösning. När du söker efter ID if($id == $record->id)
du kommer bara att matcha den aktuella nivån i trädet. d.v.s. att välja Dell med id=2 kommer inte att matcha den första iterationen så din funktion går inte vidare till nästa nivå.
Du måste hålla reda på sökvägen till din valda meny.
I ditt fall. När du väljer Dell kommer du bara att se "Dator", har jag rätt?
Vad sägs om något sånt här:
...
function rederTreeById($records, $path) {
echo '<ul>';
foreach($records as $record) {
if(in_array($record->id, $path)) {
echo '<li>'.$record->title;
if(!empty($record->childs)) {
rederTreeById($record->childs, $path);
}
echo '</li>';
} else {
echo '<li>'.$record->title.'</li>';
}
}
echo '</ul>';
}
function getPath($id) {
$path = array();
$current=$id;
$path[] = 1
while(!is_null($categories[$current]->parent_id)) {
$current=$categories[$current]->parent_id
$path[] = $current;
}
return $path;
}
$selectedId = 1;
rederTreeById($rootCategories, getPath($selectedId));
...