2017-02-16 134 views
1

您好我正在开发一个网站使用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; 
    } 
+0

显示你的mysql表的结构和它的内容 – sintakonte

+0

@sintakonte的摘录。第一个表是菜单这些字段是M_Id,Menuname第二个表名是子菜单1字段是submenu_id,menu_id,submenu_name,第三个表名是子菜单_2,这些字段是smt_id,menu_id,submenu_id,smt_name – pixel

+0

在我看来没有理由有3表 - 这是一个强制性的要求,或者你有足够的灵活性,以减少这一表 - 如果是这样我可以给你一个答案;) – sintakonte

回答

0

尝试像this.Need使多维数组。

模型

// $final = array(); 
if ($q->num_rows() > 0) { 
foreach ($q->result() as $row){ 
     $final[]['menuname'] = $row->menuname; 
     $final[]['m_id'] = $row->m_id; 
     $this->db->select("*"); 
     $this->db->from("submenu1"); 
     $this->db->where("menu_id", $row->m_id); 
     $q = $this->db->get(); 
     if ($q->num_rows() > 0) { 
      $final[]['children'] = $q->result(); 
     } 

    } 
} 
return $final; 
} 

VIEW

<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 $key=>$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 } ?> 
+0

@hi hek席子我需要添加一个子菜单.. – pixel

+0

你试过上面的代码? –

+0

@yes Hek Mat我尝试上面的代码...这是我的表格细节First Table is Menu这些字段是M_Id,Menuname第二个表名是子菜单1字段是submenu_id,menu_id,submenu_name,第三个表名是submenu_2字段是smt_id,menu_id,submenu_id,smt_name – pixel