Моя коллекция создается с использованием следующего запроса: $ClassesCollection = Classes::with('Queue')->whereIn('user_course_id', UserCourse::select('id')->where('user_id', $user->id))->get();
$ ClassesCollection возвращает желаемый результат. Однако мне нужны только результаты Queue
.
Итак, я разделил это так
$classes = [];
foreach($ClassesCollection as $class){
array_push($classes, $class->Queue);
}
А теперь у меня есть массив коллекций, каждый из которых содержит Queue
с.
Как я могу перебрать эти коллекции, чтобы отобразить содержимое каждого массива Queue
s отдельно в моем представлении?
Это то, что $classes
содержит
array:10 [▼
0 => Collection {#968 ▼
#items: array:12 [▼
0 => Queue {#841 ▶}
1 => Queue {#842 ▶}
2 => Queue {#843 ▶}
3 => Queue {#844 ▶}
4 => Queue {#845 ▶}
5 => Queue {#846 ▶}
6 => Queue {#847 ▶}
7 => Queue {#848 ▶}
8 => Queue {#849 ▶}
9 => Queue {#850 ▶}
10 => Queue {#851 ▶}
11 => Queue {#852 ▶}
]
}
1 => Collection {#969 ▶}
2 => Collection {#970 ▶}
3 => Collection {#971 ▶}
4 => Collection {#972 ▶}
5 => Collection {#973 ▶}
6 => Collection {#974 ▶}
7 => Collection {#975 ▶}
8 => Collection {#976 ▶}
9 => Collection {#977 ▶}
]
И каждый Queue
содержит несколько атрибутов, таких как date
и class_id
. Итак, что я могу сделать, чтобы отобразить содержимое каждой очереди?
РЕДАКТИРОВАТЬ: Я думал, что будет более чистый путь, но именно так я решил свою проблему для тех, кто сталкивается с этим.
$count = 0;
foreach($classes as $collection => $queue){
/*$count = count($queue) - 1;
for($i = 0; $i <= $count; $i++){
echo $queue[$i]->date."\n";
}*/
foreach($queue as $Q){
echo $Q->date."\n";
}
}
Закомментированный код также достигает желаемого эффекта.