Как использовать eloquent «with» для передачи массива из нескольких массивов в циклы - PullRequest
1 голос
/ 17 января 2020

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

<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;
use App\Activity;

class ActivityController extends Controller
{
    public function index (){
        $activities[] = [
            'yearlies' => Activity::all()
                ->where('activity_feature_type', 'yearly')
                ->sortByDesc('activity_daily_budget')
                ->take(6),
            'monthlies' => Activity::all()
                ->where('activity_feature_type', 'monthly')
                ->sortByDesc('activity_daily_budget')
                ->take(4),
            'weeklies' => Activity::all()
                ->where('activity_feature_type', 'weekly')
                ->sortByDesc('activity_daily_budget')
                ->take(4),
        ];
        return view('activities')->with('activities', $activities);
    }
}

На клиентской стороне, которую я хочу чтобы l oop через каждую переменную, чтобы поместить их в каждый UL

<div class="row pt-2">
            @if(count($yearlies) > 0)
                @foreach($activities['yearlies'] as $yearly)
                    <div class="col-sm-2">
                        <div class="card" style="width: 18rem;">
                            <img class="card-img-top" src="img/{{$yearly->activity_picture_link}}" alt="Card image cap">
                            <div class="card-body">
                                <h5 class="card-title">{{$yearly->name}}</h5>
                                <p class="card-text">{{$yearly->activity_desc_short}}</p>
                            </div>
                            <ul class="list-group list-group-flush">
                                @if ($yearly->activity_free === true)
                                    <li class="list-group-item"><h6 class="font-weight-bold">Free</h6></li>
                                @else
                                    <li class="list-group-item"><h6 class="font-weight-bold">${{$yearly->activity_low_cost}} - ${{$yearly->activity_high_cost}}</h6></li>
                                @endif
                            </ul>
                            <div class="card-body">
                                <a href="/activities/{{$yearly->id}}" class="card-link">View Activity</a>
                                <a href="/" class="card-link float-right">Save</a>
                            </div>
                        </div>
                    </div>
                @endforeach
            @else
                <h5 class="text-secondary text-center">No yearlies available</h5>
            @endif
        </div>

Надеюсь, это несколько очевидно, что я пытаюсь сделать. Несмотря на это, я искал, и все, что я вижу, - это материал о коллекциях, но я лично не определяю различные значения, поэтому я не могу использовать функциональность =>, которую они делают. Любая помощь приветствуется.

РЕДАКТИРОВАТЬ: Ниже дд $ деятельности, я хотел бы знать, как перейти к каждой строке года через этот

array:1 [▼
  0 => array:3 [▼
    "yearlies" => Illuminate\Database\Eloquent\Collection {#262 ▼
      #items: array:1 [▼
        0 => App\Activity {#295 ▼
          #table: "activities"
          #connection: "mysql"
          #primaryKey: "id"
          #keyType: "int"
          +incrementing: true
          #with: []
          #withCount: []
          #perPage: 15
          +exists: true
          +wasRecentlyCreated: false
          #attributes: array:14 [▼
            "id" => 1
            "name" => "name"
            "activity_desc_short" => "desc"
            "activity_desc" => "desc"
            "activity_free" => 0
            "activity_low_cost" => "10.50"
            "activity_high_cost" => "20.50"
            "activity_feature_type" => "yearly"
            "activity_daily_budget" => "3.00"
            "activity_picture_link" => null
            "activity_posting_business" => ""
            "location" => null
            "created_at" => "2020-01-16 21:22:18"
            "updated_at" => "2020-01-16 21:22:18"
          ]
          #original: array:14 [▶]
          #changes: []
          #casts: []
          #dates: []
          #dateFormat: null
          #appends: []
          #dispatchesEvents: []
          #observables: []
          #relations: []
          #touches: []
          +timestamps: true
          #hidden: []
          #visible: []
          #fillable: []
          #guarded: array:1 [▶]
        }
      ]
    }
    "monthlies" => Illuminate\Database\Eloquent\Collection {#288 ▶}
    "weeklies" => Illuminate\Database\Eloquent\Collection {#298 ▶}
  ]
]

Ответы [ 2 ]

2 голосов
/ 17 января 2020

Поскольку вы отправляете значение в одной переменной массива, это означает, что это многомерный массив.

Кроме того, вместо

$activities[] = [
            'yearlies' => Activity::all()
                ->where('activity_feature_type', 'yearly')
                ->sortByDesc('activity_daily_budget')
                ->take(6),
            'monthlies' => Activity::all()
                ->where('activity_feature_type', 'monthly')
                ->sortByDesc('activity_daily_budget')
                ->take(4),
            'weeklies' => Activity::all()
                ->where('activity_feature_type', 'weekly')
                ->sortByDesc('activity_daily_budget')
                ->take(4),
        ];

Используйте

$activities = [
            'yearlies' => Activity::all()
                ->where('activity_feature_type', 'yearly')
                ->sortByDesc('activity_daily_budget')
                ->take(6),
            'monthlies' => Activity::all()
                ->where('activity_feature_type', 'monthly')
                ->sortByDesc('activity_daily_budget')
                ->take(4),
            'weeklies' => Activity::all()
                ->where('activity_feature_type', 'weekly')
                ->sortByDesc('activity_daily_budget')
                ->take(4),
        ];

который уменьшит сложность массива.

Кроме того, в вашем файле blade -


<div class="row pt-2">
            @if(isset($activities) || $activities!= null)
                @foreach($activities['yearlies'] as $yearly)
                    <div class="col-sm-2">
                        <div class="card" style="width: 18rem;">
                            <img class="card-img-top" src="img/{{$yearly->activity_picture_link}}" alt="Card image cap">
                            <div class="card-body">
                                <h5 class="card-title">{{$yearly->name}}</h5>
                                <p class="card-text">{{$yearly->activity_desc_short}}</p>
                            </div>
                            <ul class="list-group list-group-flush">
                                @if ($yearly->activity_free === true)
                                    <li class="list-group-item"><h6 class="font-weight-bold">Free</h6></li>
                                @else
                                    <li class="list-group-item"><h6 class="font-weight-bold">${{$yearly->activity_low_cost}} - ${{$yearly->activity_high_cost}}</h6></li>
                                @endif
                            </ul>
                            <div class="card-body">
                                <a href="/activities/{{$yearly->id}}" class="card-link">View Activity</a>
                                <a href="/" class="card-link float-right">Save</a>
                            </div>
                        </div>
                    </div>
                @endforeach
            @else
                <h5 class="text-secondary text-center">No yearlies available</h5>
            @endif
        </div>

Я думаю, это будет работать нормально. Если я ошибаюсь, поправьте меня. Надеюсь, это работает для вас.

1 голос
/ 17 января 2020
div class="row pt-2">
            @if(count($yearlies) > 0)
                @foreach($activities->yearlies as $yearly)
                    <div class="col-sm-2">
                        <div class="card" style="width: 18rem;">
                            <img class="card-img-top" src="img/{{$yearly->activity_picture_link}}" alt="Card image cap">
                            <div class="card-body">
                                <h5 class="card-title">{{$yearly->name}}</h5>
                                <p class="card-text">{{$yearly->activity_desc_short}}</p>
                            </div>
                            <ul class="list-group list-group-flush">
                                @if ($yearly->activity_free === true)
                                    <li class="list-group-item"><h6 class="font-weight-bold">Free</h6></li>
                                @else
                                    <li class="list-group-item"><h6 class="font-weight-bold">${{$yearly->activity_low_cost}} - ${{$yearly->activity_high_cost}}</h6></li>
                                @endif
                            </ul>
                            <div class="card-body">
                                <a href="/activities/{{$yearly->id}}" class="card-link">View Activity</a>
                                <a href="/" class="card-link float-right">Save</a>
                            </div>
                        </div>
                    </div>
                @endforeach
            @else
                <h5 class="text-secondary text-center">No yearlies available</h5>
            @endif
        </div>

попробуйте

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