Подсчет общего количества сообщений пользователя в режиме просмотра лезвия

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

<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();
Другие вопросы по тегам