Heim >Backend-Entwicklung >PHP-Tutorial >Erzeugen Sie einen unendlichen Spaltenbaum mit php_php-Kenntnissen
In diesem Artikel werden hauptsächlich die relevanten Kenntnisse zum Generieren unendlicher Spaltenbäume in PHP vorgestellt. Hat einen sehr guten Referenzwert. Werfen wir einen Blick mit dem Editor unten
SpalteArray:
$arr=Array( Array('cid' => 2,'cname' => '新闻','pid' => 0), Array('cid' => 4,'cname' =>'体育','pid' => 0), Array('cid' => 5,'cname' => '娱乐','pid' => 0), Array('cid' => 7,'cname' => '热点新闻','pid' =>2), Array('cid' => 8,'cname' => '小众新闻','pid' => 2), Array('cid' => 9,'cname' => '民谣新闻','pid' => 8), );
'pid','id'=>'id','children'=>'children')){ $arr = array(); foreach ($array as &$v) { if ($v[$field['pid']] == $pid) { $v['level'] = $level; $tem = formatTree($array, $v[$field['id']],$v['level']+1,$field); //判断是否存在子数组 $tem && $v[$field['children']] = $tem; $arr[] = $v; } } return $arr; } $tree = formatTree( $arr,0,1, $field = array('pid'=>'pid','id'=>'cid','children'=>'children') ); echo ''; print_r( $tree); ?>Im Folgenden wird hauptsächlich vorgestellt, wie großartig PHP Infinitus ist Verwenden Sie geschickt die -Referenz in PHP, um die Baumgenerierungsmethode zu realisieren, die viel fortgeschrittener ist als die rekursive -Methode. Freunde, die sie benötigen, können sich auf
beziehenfunction generateTree($items){ $tree = array(); foreach($items as $item){ if(isset($items[$item['pid']])){ $items[$item['pid']]['son'][] = &$items[$item['id']]; }else{ $tree[] = &$items[$item['id']]; } } return $tree; } $items = array( 1 => array('id' => 1, 'pid' => 0, 'name' => '安徽省'), 2 => array('id' => 2, 'pid' => 0, 'name' => '浙江省'), 3 => array('id' => 3, 'pid' => 1, 'name' => '合肥市'), 4 => array('id' => 4, 'pid' => 3, 'name' => '长丰县'), 5 => array('id' => 5, 'pid' => 1, 'name' => '安庆市'), ); print_r(generateTree($items));Sie können die gedruckten Ergebnisse unten sehen:
Array ( [0] => Array ( [id] => 1 [pid] => 0 [name] => 安徽省 [son] => Array ( [0] => Array ( [id] => 3 [pid] => 1 [name] => 合肥市 [son] => Array ( [0] => Array ( [id] => 4 [pid] => 3 [name] => 长丰县 ) ) ) [1] => Array ( [id] => 5 [pid] => 1 [name] => 安庆市 ) ) ) [1] => Array ( [id] => 2 [pid] => 0 [name] => 浙江省 ) )Die obige Spanning-Tree-Methode kann auch auf 5 Zeilen vereinfacht werden:
function generateTree($items){ foreach($items as $item) $items[$item['pid']]['son'][$item['id']] = &$items[$item['id']]; return isset($items[0]['son']) ? $items[0]['son'] : array(); }Die oben genannten unendlichen Klassifizierungsdaten Baumstruktur Es lohnt sich, von dieser Methode zu lernen. Ich denke jedoch, dass die tatsächliche Verwendung dieses Codes nicht offensichtlich ist. Wenn Sie die formatierten Baumdaten herausnehmen möchten, müssen Sie immer noch Folgendes rekursieren:
/** * 如何取数据格式化的树形数据 */ $tree = generateTree($items); function getTreeData($tree){ foreach($tree as $t){ echo $t['name'].'<br>'; if(isset($t['son'])){ getTreeData($t['son']); } } } getTreeData($tree);Das obige ist der detaillierte Inhalt vonErzeugen Sie einen unendlichen Spaltenbaum mit php_php-Kenntnissen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!