2

我正在尝试将一组页面排列到一个数组中,并根据它们的父 ID 号放置它们。如果父 id 为 0,我希望将它作为数组放置在数组中,就像这样......

$get_pages = 'DATABASE QUERY'
$sorted = array()

foreach($get_pages as $k => $obj) {
    if(!$obj->parent_id) {
        $sorted[$obj->parent_id] = array();
    }
}

但是如果设置了父ID,我想把它放到相关的数组中,再次像这样的数组......

$get_pages = 'DATABASE QUERY'
$sorted = array()

foreach($get_pages as $k => $obj) {
    if(!$obj->parent_id) {
        $sorted[$obj->id] = array();
    } else if($obj->parent_id) {
        $sorted[$obj->parent_id][$obj->id] = array();
    }
}

这是我开始遇到问题的地方。如果我有第 3 个元素需要插入到数组的第 2 维,或者甚至第 4 元素需要插入第 3 维,我无法检查该数组键是否存在。所以我不知道如何检测数组键是否存在于第一个维度之后,以及它是否存在,以便我可以放置新元素。

这是我的数据库表的示例

id    page_name    parent_id

1     Products             0
2     Chairs               1
3     Tables               1
4     Green Chairs         2
5     Large Green Chair    4
6     About Us             0

这是我想要获得的输出示例,如果有更好的方法可以做到这一点,我愿意接受建议。

Array([1]=>Array([2] => Array([4] => Array([5] => Array())), [3] => Array()), 6 => Array())

先谢谢了!

4

1 回答 1

2

好吧,基本上你正在构建一棵树,所以其中一种方法是使用递归

// This function takes an array for a certain level and inserts all of the 
// child nodes into it (then going to build each child node as a parent for
// its respective children):

function addChildren( &$get_pages, &$parentArr, $parentId = 0 )
{
    foreach ( $get_pages as $page )
    {
        // Is the current node a child of the parent we are currently populating?

        if ( $page->parent_id == $parentId )
        {
            // Is there an array for the current parent?

            if ( !isset( $parentArr[ $page->id ] ) )
            {
                // Nop, create one so the current parent's children can
                // be inserted into it.

                $parentArr[ $page->id ] = array();
            }

            // Call the function from within itself to populate the next level
            // in the array:

            addChildren( $get_pages, $parentArr[ $page->id ], $page->id );
        }
    }
}


$result = array();
addChildren( $get_pages, $result );

print_r($result);

这不是最有效的方法,但对于少数页面和层次结构,你应该没问题。

于 2012-04-23T10:30:43.943 回答