РЕШЕНО! Окончательный ответ находится внизу этого вопроса
Я пытаюсь создать конструктор меню с помощью CodeIgniter, и по какой-то причине я не могу понять эту концепцию, хотя она кажется достаточно простой (Я новичок в PHP и CI ). На самом деле это должно иметь меньшее отношение к самому CodeIgniter, поскольку я действительно использую его только для запросов и шаблона MVC.
У меня есть две таблицы:
меню:
меню _страницы:
РЕДАКТИРОВАТЬ :Это структура, которую я хочу получить:
array(
[0] => array(
[menu_id] => 1,
[menu_name] => 'Menu 1',
[menu_pages] => array(
[0] => array(
[id] => 1,
[page_id] => 1,
[menu_id] => 1,
[item_name] => 'Home',
[item_order] => 0,
[item_level] => 0,
[parent_id] => ''
),
[1] => array(
[id] => 2,
[page_id] => 2,
[menu_id] => 1,
[item_name] => 'About',
[item_order] => 0,
[item_level] => 0,
[parent_id] => ''
)
)
),
[1] => array(
[menu_id] => 2,
[menu_name] => 'Menu 2',
[menu_pages] => array(
[0] => array(
[id] => 3,
[page_id] => 3,
[menu_id] => 2,
[item_name] => 'Services',
[item_order] => 0,
[item_level] => 0,
[parent_id] => ''
),
[1] => array(
[id] => 4,
[page_id] => 4,
[menu_id] => 2,
[item_name] => 'Contact',
[item_order] => 0,
[item_level] => 0,
[parent_id] => ''
)
)
)
)
Вот что у меня есть (ОБНОВЛЕНО):
function GetMenus() {
$menus = $this->db->get('menus');
$menucols = $this->db->list_fields('menus');
$pages = $this->db->get('menu_pages');
$pagecols = $this->db->list_fields('menu_pages');
$arr = array();
$i = 0;
foreach($menus->result() as $menu) {
foreach($pages->result() as $page) {
foreach($pagecols as $col) {
$arr[$i][$col] = $page->$col;
}
foreach($menucols as $cols) {
$this->menus[$i][$cols] = $menu->$cols;
if($arr[$i]['menu_id'] === $menu->id) {
$this->menus[$i]['menu_pages'] = $arr[$i];
}
}
}
$i++;
}
return $this->menus;
}
Приведенное выше фактически выводит это:
Array(
[0] => Array(
[id] => 1,
[name] => default,
[menu_pages] => Array(
Array( /* missing #1, showing #2/2 */
[id] => 2
[page_id] => 1
[menu_id] => 1
[item_name] => About
[item_order] => 0
[item_level] => 0
[parent_id] =>
)
)
),
[1] => Array(
[id] => 2,
[name] => menu2,
[menu_pages] => Array(
Array( /* missing #3, showing #4/4 */
[id] => 4
[page_id] => 3
[menu_id] => 2
[item_name] => Contact
[item_order] => 0
[item_level] => 0
[parent_id] =>
)
)
)
)
Как вы можете видеть, это довольно близко к тому, что мне нужно, но есть пропущенные элементы, потому что кажется, что они перезаписываются в массиве (он показывает только последний пункт меню для каждого меню -, кажется, возможно у них одинаковые ключи ).
Спасибо за любую помощь и предложения!
РЕДАКТИРОВАТЬ :Вот окончательное решение, основанное на ответе Миши:
Модель:
function GetMenus() {
/* Yes, I know these can be chained, I unchained them to avoid
horizontal scrolling on SO */
$this->db->select('menus.name, menu_pages.*, pages.slug');
$this->db->join('menu_pages', 'menu_pages.menu_id = menus.id');
$this->db->join('pages', 'pages.id = menu_pages.page_id');
$this->db->order_by('item_order', 'ASC');
$menus = $this->db->get('menus');
$result = array();
foreach($menus->result() as $menu) {
$result[$menu->name][$menu->id] = array(
'page_id' => $menu->page_id,
'menu_id' => $menu->menu_id,
'item_name' => $menu->item_name,
'item_slug' => $menu->slug,
'item_order' => $menu->item_order,
'item_level' => $menu->item_level,
'parent_id' => $menu->parent_id
);
}
return $result;
}
Контроллер:
$this->menu = $this->page->GetMenus();
Посмотреть:
<ul class="nav">
<?php foreach($this->menu['default'] as $item) { ?>
<li>
<a href="<?php echo $item['item_slug']; ?>">
<?php echo $item['item_name']; ?>
</a>
</li>
<?php } ?>
</ul>