Is there a way to do a foreach on for example your products and sort this by their category_id and show the category name above the products.
Example what the output should look like:
Chairs
wooden chair number 1
pretty chair number 1
pretty chair number 2
Doors
tall door number 1
white door number 1
Key question: How can i make a foreach without having the categoryname above each row ?
Hopefully i made my question/problem clear and can someone help me out!
One way is to prepare your data first
foreach ($products as $product) {
$category[$product->category_id][] = $product;
}
and then display the products in your view for each category id.
ok. i will try to give an example based on you sample code. First in the controller we prepare data to our needs
foreach($results as $result) {
$categories[$result->category_id]['name'] = 'Category name for the specific category id from db using eloquent or something';
$categories[$result->category_id]]['products'][] = $row;
}
And then in view we iterate through the arrays
//iterate categories array
@foreach($categories as $category_with_products)
{{ $category_products['title'] }}
//iterate products array of objects for the specific category
@foreach($category_products['products'] as $product)
{{ $product->name }}
@endforeach
@endforeach
Hope that helps. I have checked the code and it is working as expected.
lorienhd said:
Thanks ! Working like a charm
It seems that you figured out what to do while i was elaborating more on the issue ;-)
Sign in to participate in this thread!
The Laravel portal for problem solving, knowledge sharing and community building.
The community