Heim >Backend-Entwicklung >PHP-Tutorial >Best Practices für die unendliche PHP-Klassifizierung
ist eine sehr häufige und notwendige Funktion, fast jedes Projekt verfügt über sie.
Anwendungsszenarien: Dropdown-Listen, Baumlisten usw.
Front-End-Implementierung (Das Front-End-Framework wurde im Allgemeinen implementiert und kann generiert werden, solange das Back-End Daten im angegebenen Format an das Front-End überträgt)
Back-End-Implementierung(Im Folgenden geht es hauptsächlich um diese Art der Implementierung)
Der erste Typ (empfohlen)
function infiniteSort($data, $showFName, $titleFName, $pidFName = 'pid', $idFName = 'id', $levelFName = 'level', $pid = 0, $level = 0) { $tree = array(); foreach ($data as $key => $value) { if ($value[$pidFName] == $pid) { $value[$levelFName] = $level; $value[$showFName] = str_repeat(' ', $level) . '|-' . $value[$titleFName]; $tree[] = $value; unset($data[$key]); $tempArr = infiniteSort($data, $showFName, $titleFName, $pidFName, $idFName, $level, $value[$idFName], $level + 1); if(!empty($tempArr)){ $tree = array_merge($tree, $tempArr); } } } return $tree; }
Hinweis:
1. $data Alle Daten, die vorhanden sind sortiert nach aufsteigend
2. $showFName Der Feldname des Anzeigenamens (formatiert)
3. $titleFName Der Feldname des Titels (unformatiert)
4. $levelFName Ebenenfeldname
5. $pidFName Feldname der übergeordneten ID
6. $idFName Feldname der ID
Der zweite Typ (unter Verwendung von Referenzvariablen)
/** * 无限级分类 * @param Array $treeList //接受处理完成数据的数组 * @param Array $data //数据库里获取的结果集 * @param String $level //格式化层级字段名 * @param Int $pid * @param Int $count //第几级分类 */ function tree(&$treeList, &$data, $level, $show_name, $field_name, $field_pid = 'pid', $field_id = 'id', $pid = 0, $count = 0) { foreach ($data as $key => $value) { if ($value[$field_pid] == $pid) { $value[$level] = $count; $value[$show_name] = str_repeat(' ',$count).'|-'.$value[$field_name]; $treeList[] = $value; unset($data[$key]); tree($treeList, $data, $level, $show_name, $field_name,$field_pid, $field_id, $value[$field_id], $count+1); } } }
Hinweis:
1 . $data Alle Daten, die nach ASC sortiert wurden
2. Die zurückgegebenen Listendaten auf unendlicher Ebene werden in $treeList
gespeichert dritter Typ (Es gibt Einschränkungen bei der Verwendung statischer Variablen: Wenn eine Anfrage zweimal aufgerufen wird. Wenn Sie 2 unendliche Klassifizierungsebenen implementieren möchten, treten Probleme auf, daher wird dies nicht empfohlen)
public function getTree($list, $parent_id, $level=0) { //应该是静态的局部变量,这样才能保证,在递归调用时,所有 //的getTree方法,操作的是一个Tree空间。 static $tree = array();//保存找到的分类的数组 //遍历所有分类,通过parent_id判断,哪些是我们正在查找的 foreach($list as $row) { //判断当前所遍历的分类$row, 是否是当前需要查找的子分类 if($row['pid'] == $parent_id) { //找到了一个分类 //存起来,存哪? $row['level'] = $level; $tree[] = $row; //继续查找当前$row所代表的分类的子分类 $this->getTree($list, $row['id'], $level+1); } } return $tree; }
Hinweis:
1. $list Alle Daten, die nach aufsteigend sortiert wurden
ist eine sehr häufige und notwendige Funktion, fast jedes Projekt hat sie.
Anwendungsszenarien: Dropdown-Listen, Baumlisten usw.
Front-End-Implementierung (Das Front-End-Framework wurde im Allgemeinen implementiert und kann generiert werden, solange das Back-End Daten im angegebenen Format an das Front-End überträgt)
Back-End-Implementierung(Im Folgenden geht es hauptsächlich um diese Art der Implementierung)
Der erste Typ (empfohlen)
function infiniteSort($data, $showFName, $titleFName, $pidFName = 'pid', $idFName = 'id', $levelFName = 'level', $pid = 0, $level = 0) { $tree = array(); foreach ($data as $key => $value) { if ($value[$pidFName] == $pid) { $value[$levelFName] = $level; $value[$showFName] = str_repeat(' ', $level) . '|-' . $value[$titleFName]; $tree[] = $value; unset($data[$key]); $tempArr = infiniteSort($data, $showFName, $titleFName, $pidFName, $idFName, $level, $value[$idFName], $level + 1); if(!empty($tempArr)){ $tree = array_merge($tree, $tempArr); } } } return $tree; }
Hinweis:
1 $data Alle Daten, die nach aufsteigend sortiert wurden
2 , $showFName Zeigt den Feldnamen des Namens an (formatiert)
3. $titleFName Der Feldname von der Titel (unformatiert)
4. $levelFName Ebenenfeldname
5. $pidFName Feldname der übergeordneten ID
6 🎜>Feldname der ID
Zweiter Typ (unter Verwendung von Referenzvariablen)
/** * 无限级分类 * @param Array $treeList //接受处理完成数据的数组 * @param Array $data //数据库里获取的结果集 * @param String $level //格式化层级字段名 * @param Int $pid * @param Int $count //第几级分类 */ function tree(&$treeList, &$data, $level, $show_name, $field_name, $field_pid = 'pid', $field_id = 'id', $pid = 0, $count = 0) { foreach ($data as $key => $value) { if ($value[$field_pid] == $pid) { $value[$level] = $count; $value[$show_name] = str_repeat(' ',$count).'|-'.$value[$field_name]; $treeList[] = $value; unset($data[$key]); tree($treeList, $data, $level, $show_name, $field_name,$field_pid, $field_id, $value[$field_id], $count+1); } } }Hinweis :
1. $data
wurde nach ASC sortiert. Alle Daten 2. Die zurückgegebenen unendlichen Listendaten werden in $treeList
(es gibt Einschränkungen bei der Verwendung statischer Variablen: Wenn eine Anfrage zweimal aufgerufen wird, um zwei unendliche Klassifizierungen zu implementieren, treten Probleme auf, daher wird dies nicht empfohlen)
public function getTree($list, $parent_id, $level=0) { //应该是静态的局部变量,这样才能保证,在递归调用时,所有 //的getTree方法,操作的是一个Tree空间。 static $tree = array();//保存找到的分类的数组 //遍历所有分类,通过parent_id判断,哪些是我们正在查找的 foreach($list as $row) { //判断当前所遍历的分类$row, 是否是当前需要查找的子分类 if($row['pid'] == $parent_id) { //找到了一个分类 //存起来,存哪? $row['level'] = $level; $tree[] = $row; //继续查找当前$row所代表的分类的子分类 $this->getTree($list, $row['id'], $level+1); } } return $tree; }1. $list
ist bereits alle Daten nach ASC sortiert
Für weitere Artikel im Zusammenhang mit Best Practices für die unendliche PHP-Klassifizierung zahlen Sie bitte Achtung auf die chinesische PHP-Website!