Laravel. Използвайте scope() в модели с релация

Имам два свързани модела: Category и Post.

Моделът Post има published обхват (метод scopePublished()).

Когато се опитам да получа всички категории с този обхват:

$categories = Category::with('posts')->published()->get();

Получавам грешка:

Извикване на недефиниран метод published()

Категория:

class Category extends \Eloquent
{
    public function posts()
    {
        return $this->HasMany('Post');
    }
}

Публикуване:

class Post extends \Eloquent
{
   public function category()
   {
       return $this->belongsTo('Category');
   }


   public function scopePublished($query)
   {
       return $query->where('published', 1);
   }

}

person Ilya Vo    schedule 03.10.2014    source източник


Отговори (1)


Можете да го направите инлайн:

$categories = Category::with(['posts' => function ($q) {
  $q->published();
}])->get();

Можете също да дефинирате връзка:

public function postsPublished()
{
   return $this->hasMany('Post')->published();
   // or this way:
   // return $this->posts()->published();
}

и тогава:

//all posts
$category->posts;

// published only
$category->postsPublished;

// eager loading
$categories->with('postsPublished')->get();
person Jarek Tkaczyk    schedule 03.10.2014
comment
Между другото, ако искате да стигнете САМО там, където сте публикували публикации: Category::whereHas('posts', function ($q) { $q->published(); })->get(); - person tptcat; 31.01.2017
comment
@tptcat да. Също така може да бъде Category::has('postsPublished') в този случай - person Jarek Tkaczyk; 01.02.2017
comment
Чист въпрос, чист отговор! - person Mojtaba Hn; 12.10.2019