我正在尝试显示按类别分组的餐厅菜单,例如...
- 午餐
- 鸡肉和薯条
- 米饭
- 早餐
- 茶
- 咖啡
所以我的数据库中有 3 个表,餐厅、类别和菜单
类别模型
class Category extends Model
{
protected $fillable = [
'name'
];
/**
* @return \Illuminate\Database\Eloquent\Relations\HasMany
*/
public function menus_type()
{
return $this->hasMany('App\Menu','category_id');
}
}
菜单模型
class Menu extends Model
{
protected $fillable = [
'name',
'price',
'description',
'photoPath',
'restaurant_id',
'category_id',
];
/**
* Menu belongs to Restaurant
*/
public function restaurant()
{
return $this->belongsTo('App\Restaurant');
}
/**
* Menu belongs to category type
*/
public function category_type()
{
return $this->belongsTo('App\Category', 'category_id');
}
}
餐厅管理员
public function show($slug, RestaurantRepository $repository){
if(! $restaurant = $repository->get(['slug' => $slug], with(['cuisines','user', 'photos', 'thumbs', 'region', 'ratings.user']))) return abort('404');
$menus=Menu::with(['category_type'])->where('restaurant_id',$restaurant->id)->get()->groupBy('category_id');
return view('frontend.restaurant.show', compact('restaurant', 'p','menus'));
}
当我转储时,它看起来很好。
结果已经分组
现在我的问题出在 View 上,当我尝试获取结果时出现错误。
@if($menus)
<ul>
@foreach($menus as $m)
<li>
{{$m->name}}
</li>
@endforeach
</ul>
@endif
ErrorException (E_ERROR).
Property [name] does not exist on this collection instance.
最佳答案
也迭代内循环。 'groupBy()' 创建另一个以 category_id
作为键的数组。
@if($menus)
<ul>
@foreach($menus as $category_id=>$outer)
@foreach($outer as $k=>$inner)
<li>
{{$category_id}}: {{$inner->name}}
</li>
@endforeach
@endforeach
</ul>
@endif
更新了您的查询以从类别中获取
$categories = Category::with('menus_type')->get();
return view('frontend.restaurant.show', compact('restaurant', 'p','categories '));
在你看来
@if($categories ?? false)
<ul>
@foreach($categories ?? [] as $cat_key=>$category)
<li>
{{$category->name}}
</li>
<li>
<ul>
@foreach($category->menus_type as $menu_key=>$menu)
<li>
{{$menu->name}}
</li>
@endforeach
</ul>
</li>
@endforeach
</ul>
@endif
关于php - 我如何在 Laravel 中显示分组值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58074873/