您好我正在开发一个网站使用codeigniter multidimentional动态菜单。我使用codeingiter和MySQL我有创建菜单,子菜单1,子菜单2。现在Menu和Submenu1正在加载网站,但我尝试加载submenu2我得到的问题,我在php中使用array_push方法。这是我在此代码代码我已经加载菜单和submenu1任何机构可以帮助我如何加载submenu2也...Codeingniter with mysql Multidementional动态菜单创建?
这是我的看法代码..
<div class="collapse navbar-collapse">
<ul class="nav navbar-nav">
<li class="active"><a href="<?php echo base_url()?>Pixel/index" >Home</a></li>
<?php foreach($menus as $menu) { ?>
<li id="mainmenu">
<a href="#" class="dropdown-toggle" id="<?php echo $menu->m_id; ?>" data-toggle="dropdown"> <?php echo $menu->menuname; ?> <b class="caret"></b></a>
<ul class="dropdown-menu">
<?php
if (isset($menu->children)) {
foreach ($menu->children as $child) {
?>
<li>
<a href="<?php echo base_url()?>Pixel/corporate" id="submenuone" class="dropdown-toggle"><?php echo $child->submenu_name; ?>
</a>
</li>
<?php
}
} ?>
</ul>
</li>
<?php } ?>
这是我的控制器代码
public function index()
{
$menus = $this->Px_Model->populateMenus();
$data = array('menus' => $menus);
$this->load->view('pxHead');
$this->load->view('pxHeader');
$this->load->view('pxNav',$data);
$this->load->view('pxSlider');
$this->load->view('pxHome');
$this->load->view('pxFooter');
}
这是我的模型代码
public function populateMenus(){
$this->db->select("*");
$this->db->from("menu");
$q = $this->db->get();
$final = array();
if ($q->num_rows() > 0) {
foreach ($q->result() as $row){
$this->db->select("*");
$this->db->from("submenu1");
$this->db->where("menu_id", $row->m_id);
$q = $this->db->get();
if ($q->num_rows() > 0) {
$row->children = $q->result();
}
array_push($final, $row);
}
}
return $final;
}
显示你的mysql表的结构和它的内容 – sintakonte
@sintakonte的摘录。第一个表是菜单这些字段是M_Id,Menuname第二个表名是子菜单1字段是submenu_id,menu_id,submenu_name,第三个表名是子菜单_2,这些字段是smt_id,menu_id,submenu_id,smt_name – pixel
在我看来没有理由有3表 - 这是一个强制性的要求,或者你有足够的灵活性,以减少这一表 - 如果是这样我可以给你一个答案;) – sintakonte