$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' => 2, 'name' => '哈爾濱市'),
6 => array('id' => 6, 'pid' => 3, 'name' => '清華大學'),
5 => array('id' => 5, 'pid' => 2, 'name' => '雞西市'),
7 => array('id' => 7, 'pid' => 3, 'name' => '北京大學')
);
print_r($this->genTree5($items));
//這個函數怎麼了解
public function genTree5($items) {
foreach ($items as $item)
$items[$item['pid']]['son'][$item['id']] = &$items[$item['id']];
return isset($items[0]['son']) ? $items[0]['son'] : array();
}
我在網上找的無限分類轉換n維數組,5行就完成了,我看不懂啊。也看不到他哪遞歸了,然而就是這麼牛。跟蹤調試一下,$items[$item['pid']]'son'];就這裡一直重複執行。然後就能輸出多元數組,感覺好強大。誰能幫我分析一下,他這個是咋個執行的邏輯。
我比較菜,還有點笨,就是喜歡代碼這東西。
Array
(
[1] => Array
(
[id] => 1
[pid] => 0
[name] => 北京市
[son] => Array
(
[3] => Array
(
[id] => 3
[pid] => 1
[name] => 海澱區
[son] => Array
(
[6] => Array
(
[id] => 6
[pid] => 3
[name] => 清華大學
)
[7] => Array
(
[id] => 7
[pid] => 3
[name] => 北京大學
)
)
)
)
)
[2] => Array
(
[id] => 2
[pid] => 0
[name] => 黑龍江省
[son] => Array
(
[4] => Array
(
[id] => 4
[pid] => 2
[name] => 哈爾濱市
)
[5] => Array
(
[id] => 5
[pid] => 2
[name] => 雞西市
)
)
)
)