[英]Get Parent and Child depth level from JSON using PHP?
我有這樣的樹狀結構
然后像這樣獲取JSON值
[{"id":1,"children":[{"id":3,"children":[{"id":9,"children":[{"id":8}]}]}]},{"id":10,"children":[{"id":11,"children":[{"id":13}]},{"id":12}]}]
我需要使用PHP從此JSON中找到子級的子級和父級ID。
所以我想輸出會像這樣
id=>1, parent_id=>0, level=>0
id=>3, parent_id=>1, level=>1
id=>9, parent_id=>3, level=>2
id=>8, parent_id=>9, level=>3
id=>10, parent_id=>0, level=>0
id=>11, parent_id=>10, level=>1
id=>13, parent_id=>11, level=>2
id=>12, parent_id=>10, level=>1
謝謝
嘗試這樣的事情:
$jsonString = '[{"id":1,"children":[{"id":3,"children":[{"id":9,"children":[{"id":8}]}]}]},{"id":10,"children":[{"id":11,"children":[{"id":13}]},{"id":12}]}]';
$jsonArray = json_decode($jsonString);
function read_tree_recursively($items, $parent_id = 0, $result = array(), $level = 0) {
foreach($items as $child) {
$result[$child->id] = array(
'id' => $child->id,
'parent_id' => $parent_id,
'level' => $level
);
if (!empty($child->children)) {
$result = read_tree_recursively($child->children, $child->id, $result, $level+1);
}
}
return $result;
}
// usage
read_tree_recursively($jsonArray);
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.