我从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
的视图上创建了这个,有一个更好的方法来制作菜单,或者我以正确的方式制作了这个菜单?
答案 0 :(得分:3)
menus
表格
id - parent_id - title - url - order - created_at - updated_at
制作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
你可以随心所欲地制作控制器
这种方式我花了一整天的时间来尝试获取这个有效的代码,当我完成后我决定搜索任何人要求这个问题
玩得开心:)