Подсчет общего количества сообщений пользователя в режиме просмотра лезвия
Я отправил коллекцию всех сообщений в своем блоге в индексное представление, а затем использовал следующий код для подсчета общего количества сообщений, сделанных каждым пользователем.
<p class="joined-text">Posts: {{count(App\Posts::where('user_id', $post->user->id)->get())}}</p>
Это плохая практика, чтобы делать это из вида лезвия? Если это так, как бы я достиг этого?
модели
class Posts extends Model
{
public function user()
{
return $this->belongsTo(User::class);
}
public function comments()
{
return $this->hasMany(Comments::class, 'post_id');
}
}
class User extends Authenticatable
{
public function posts()
{
return $this->hasMany('\App\Posts::class');
}
public function comments()
{
return $this->hasMany(Comments::class);
}
}
2 ответа
Решение
Простое решение:
<p class="joined-text">Posts: {{ App\Posts::where('user_id', $post->user_id)->count() }}</p>
обновленный
Полное и лучшее решение:
Post.php
:
public function user(){
return $this->belongsTo(App\User::class);
}
User.php
:
public function posts(){
return $this->hasMany(App\Post::class);
}
public function getPostsCountAttribute(){
return $this->posts()->count();
}
лезвие:
<p class="joined-text">Posts: {{ $post->user->posts_count }}</p>
Да, это плохо.
Вы можете использовать отношения, если есть user_id
поле в posts
Таблица
class User extends Model
{
public function posts()
{
return $this->hasMany('App\Post');
}
}
В контроллере
return view('sth')->with(['posts'=>$user->posts]);
Тогда ввиду
$posts->count();
Или просто получить счет, если вам не нужны сообщения
$postCount = $user->posts()->count();