动态菜单laravel

时间:2014-08-07 17:10:26

标签: php twitter-bootstrap laravel-4

我从laravel开始,并与bootstrap集成。我想制作一个菜单栏,以便按年访问信息,菜单以我的方式进入视图

<li class="dropdown-submenu">
    <a tabindex="-1" href="#">2007</a>
    <ul class="dropdown-menu">
        <li><a tabindex="-1" href="<?php echo url('/convenios/2007/registrar', $parameters = array(), $secure = null); ?>">Registrar</a></li>
        <li><a href="#">Consultar</a></li>
    </ul>
</li>

我在一个名为base.blade.php的视图上创建了这个,有一个更好的方法来制作菜单,或者我以正确的方式制作了这个菜单?

1 个答案:

答案 0 :(得分:3)

menus表格

id - parent_id - title - url - order - created_at - updated_at

enter image description here

制作Menu模型

class Menu extends Model
{

  public $timestamps = false;

  protected $table = 'menus';

  protected $fillable = array('parent_id','title','url','order');

  public function parent()
  {
    return $this->belongsTo('App\Menu', 'parent_id');
  }

  public function children()
  {
    return $this->hasMany('App\Menu', 'parent_id');
  }
}

在视图中

@foreach(App\Menu::orderBy('order','asc')->get() as $menuItem)

  @if( $menuItem->parent_id == 0 )
     <li {{ $menuItem->url ? '' : "class=dropdown" }}>
     <a href="{{ $menuItem->children->isEmpty() ? $menuItem->url : "#" }}"{{ $menuItem->children->isEmpty() ? '' : "class=dropdown-toggle data-toggle=dropdown role=button aria-expanded=false" }}>
        {{ $menuItem->title }}
     </a>
  @endif

  @if( ! $menuItem->children->isEmpty() )
    <ul class="dropdown-menu" role="menu">
      @foreach($menuItem->children as $subMenuItem)
          <li><a href="{{ $subMenuItem->url }}">{{ $subMenuItem->title }}</a></li>
      @endforeach
    </ul>
  @endif
  </li> 

@endforeach

你可以随心所欲地制作控制器

这种方式我花了一整天的时间来尝试获取这个有效的代码,当我完成后我决定搜索任何人要求这个问题

玩得开心:)