Heim >Backend-Entwicklung >PHP-Tutorial >Einführung in die Implementierungsmethode zur Generierung eines Klassifizierungsbaums mithilfe der PHP-Infinitus-Klassifizierung
In diesem Artikel wird hauptsächlich die Methode von PHP zur Implementierung der Infinitus-Klassifizierung zum Generieren eines Klassifizierungsbaums vorgestellt. Er analysiert kurz die Prinzipien und Implementierungsmethoden der Infinitus-Klassifizierung in Form von Beispielen und beinhaltet PHP-Array-Traversal- und Beurteilungsfunktionen Wer es braucht, kann darauf verweisen.
Das Beispiel in diesem Artikel beschreibt die Methode zum Generieren eines Klassifizierungsbaums für die Infinitus-Klassifizierung mit PHP. Teilen Sie es als Referenz mit allen. Die Details lauten wie folgt:
Das aktuelle Design der Klassifizierungsdatenbank sieht im Grunde so aus: Jede Klassifizierung hat ein ID-Primärschlüsselfeld und eine PID zeigt auf die ID der übergeordneten Klasse dass unbegrenzte Klassifizierungsstufen erreicht werden können:
$arr = array( array("id" => 1 , "pid" => 0 , 'cat' => '栏目一'), array("id" => 2 , "pid" => 0 , 'cat' => '栏目二'), array("id" => 3 , "pid" => 1 , 'cat' => '栏目三'), array("id" => 4 , "pid" => 2 , 'cat' => '栏目四'), array("id" => 5 , "pid" => 1 , 'cat' => '栏目五'), array("id" => 6 , "pid" => 5 , 'cat' => '栏目六'), array("id" => 7 , "pid" => 5 , 'cat' => '栏目七'), array("id" => 8 , "pid" => 6 , 'cat' => '栏目八'), array("id" => 9 , "pid" => 1 , 'cat' => '栏目九'), array("id" => 10 , "pid" => 0 , 'cat' => '栏目十'), array("id" => 11 , "pid" => 10 , 'cat' => '栏目十一'), array("id" => 12 , "pid" => 11 , 'cat' => '栏目十二'), array("id" => 13 , "pid" => 2 , 'cat' => '栏目十三'), array("id" => 14, "pid" => 13 , 'cat' => '栏目十四') );
Nicht viel zu sagen, gehen wir direkt zum Verarbeitungscode:
//生成无限极分类树 function make_tree($arr){ $refer = array(); $tree = array(); foreach($arr as $k => $v){ $refer[$v['id']] = & $arr[$k]; //创建主键的数组引用 } foreach($arr as $k => $v){ $pid = $v['pid']; //获取当前分类的父级id if($pid == 0){ $tree[] = & $arr[$k]; //顶级栏目 }else{ if(isset($refer[$pid])){ $refer[$pid]['subcat'][] = & $arr[$k]; //如果存在父级栏目,则添加进父级栏目的子栏目数组中 } } } return $tree; }
Test Lauf:
$cat = make_tree($arr); print_r($cat);
Laufergebnisse:
Array ( [0] => Array ( [id] => 1 [pid] => 0 [cat] => 栏目一 [subcat] => Array ( [0] => Array ( [id] => 3 [pid] => 1 [cat] => 栏目三 ) [1] => Array ( [id] => 5 [pid] => 1 [cat] => 栏目五 [subcat] => Array ( [0] => Array ( [id] => 6 [pid] => 5 [cat] => 栏目六 [subcat] => Array ( [0] => Array ( [id] => 8 [pid] => 6 [cat] => 栏目八 ) ) ) [1] => Array ( [id] => 7 [pid] => 5 [cat] => 栏目七 ) ) ) [2] => Array ( [id] => 9 [pid] => 1 [cat] => 栏目九 ) ) ) [1] => Array ( [id] => 2 [pid] => 0 [cat] => 栏目二 [subcat] => Array ( [0] => Array ( [id] => 4 [pid] => 2 [cat] => 栏目四 ) [1] => Array ( [id] => 13 [pid] => 2 [cat] => 栏目十三 [subcat] => Array ( [0] => Array ( [id] => 14 [pid] => 13 [cat] => 栏目十四 ) ) ) ) ) [2] => Array ( [id] => 10 [pid] => 0 [cat] => 栏目十 [subcat] => Array ( [0] => Array ( [id] => 11 [pid] => 10 [cat] => 栏目十一 [subcat] => Array ( [0] => Array ( [id] => 12 [pid] => 11 [cat] => 栏目十二 ) ) ) ) ) )
Das obige ist der detaillierte Inhalt vonEinführung in die Implementierungsmethode zur Generierung eines Klassifizierungsbaums mithilfe der PHP-Infinitus-Klassifizierung. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!