laravel Как отобразить элементы одной категории на взаимосвязи между таблицами элементов и категорий - PullRequest
0 голосов
/ 24 июня 2018

Я задавал этот вопрос раньше, но не получил никакого ответа, надеюсь, у вас есть решение. У меня есть 2 таблицы, предметы и категории, поэтому у каждого предмета есть одна категория, и у одной категории может быть много предметов. моя проблема заключается в использовании групповой функции, но она показывает один элемент для каждой категории

модель товара:

 class Item extends Model
{
 protected $table="items";
protected $fillable= 
['item_title','category_id','item_price','item_details','item_image'];
protected $primaryKey='item_id';
public $timestamps=false;

public function categories()
{
$this->hasOne('App\category','category_id','category_id');
}
}

категория модели

class Category extends Model
{
protected $table="categories";
protected $fillable=['category_name'];
protected $primaryKey='category_id';
public $timestamps=false;

  public function items()
  {
    $this->hasMany('App\items','category_id','category_id');
  }
  }

Контроллер

class HomeController extends Controller
{
public function getItems()
{
$items = Item::groupBy('category_id')->get();   
return view('home',compact('items'));
}
}

HTML

 @foreach($items as $indexKey => $item)
<div class="MenuPage_contentArea">
<div class="Category_root" id="one">
<div class="Category_categoryHeader">

<div><h2 class="Category_name">{{$item->item_category}}</h2></div>
<div class="Category_description"></div>
</div>

  <div class="Category_itemsContainer">
  <div class="Category_itemContainer">
  <button class="Item_root Button_root">
  <div class="Item_image" style="background-image: url('{{ asset('images/' . $item->item_image) }}');"></div>

<div class="Item_itemContent">
<div class="Item_topSection">
<span class="Item_name">{{$item->item_title}}</span>

<span class="Item_price">${{$item->item_price}}</span></div>
<div class="Item_description">{{$item->item_details}}</div>
</div>
</button>
</div>
</div>
</div>
</div>
@endforeach

1 Ответ

0 голосов
/ 24 июня 2018

Вы группируете на уровне SQL, но если вы хотите, чтобы все элементы категории были сгруппированы в Коллекцию, используйте метод groupBy из Collection.Используйте метод all(), чтобы получить коллекцию всех элементов, затем используйте метод groupBy(), чтобы сгруппировать items по category_id:

HOME CONTROLLER

Класс HomeController расширяет Контроллер

{
    public function getItems()
    {
        $items = Item::all()->groupBy('category_id');   
        return view('home',compact('items'));
    }
}

Доступ в вашем блейде Файл как:

@foreach($items as $category_id => $categoryItems)
   Category ID: {{ $category_id }} <br>
   @foreach($categoryItems as $item)
     <!-- Display Item Details Here -->
   @endforeach
@endforeach

Надеюсь, он вам поможет.:)

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...