Laravel 按需访问关系

Laravel Accessor on demand on relationship

问题: 我在 Size.php 模型中有访问器,它在与 Item.php 模型的关系中调用,在 API 中我需要访问器工作,但在其他控制器中我想禁用访问器。我已从所有文件中删除 unnecessary/unrelated 代码。

我想做的事情:

在 ItemControllerAPI 中我需要访问器才能工作,但我想在其他控制器中禁用访问器。

我已经看到了: 我已经看过这些链接,但对我不起作用。

1: https://laracasts.com/discuss/channels/eloquent/accessor-on-demand-but-not-on-every-results

2:

3: https://laracasts.com/discuss/channels/general-discussion/eager-load-accessors

Size.php(型号)

class Size extends Model
{
    protected $appends = ['addons'];

    public function items()
    {
        return $this->belongsToMany('App\Item', 'items_sizes')->withPivot('price');//->withTimestamps();
    }

    public function getAddonsAttribute($value)
    {
        $addon = Addon::where('addons.category_id', $this->category_id)
            ->where('size_id', $this->id)
            ->get();
        return $addon;
    }
}

Item.php(型号)

class Item extends Model
{
    public function options()
    {
        return $this->belongsToMany('App\Option', 'items_options')->withTimestamps();
    }

    public function sizes()
    {
        return $this->belongsToMany('App\Size', 'items_sizes')->withPivot('price');//->withTimestamps();
    }
}

ItemControllerAPI.php(控制器)

class ItemControllerAPI extends BaseControllerAPI
{
    public function show($id)
    {
        // If i call the Size model directly by using setAppends([]) its working fine, 
        // its removing the appended array from Size model

        // $size = Size::all();
        // $size->each->setAppends([]);
        // return $size;

        // If i use it with relationship it won't work.

        // $itemSingleQuery = Item::with(['sizes' => function($query)
        // {
              // Doesn't work
              // $query->setAppends([]);
              // Doesn't work
              // $query->each->setAppends([]);
         // }])
         // ->with('options')
         // ->where('id', $id)
         // ->get();

        // query for getting data with relationships
        $itemSingleQuery = Item::with('sizes')
            ->with('options')
            ->where('id', $id)
            ->get();

         return $this->respondSuccess('content found', $itemSingleQuery);
    }
}

我建议您在需要时设置$appends

$itemSingleQuery->pluck('sizes')->collapse()->each->setAppends(['addons']);

我已经找到了如何做到这一点:

获得整个集合后,我们需要在每个包含附加项的模型中调用 setAppends(),以便在序列化为数组或 JSON.

之前添加或删除它们
$itemSingleQuery = Item::with('sizes')->get();

$itemSingleQuery->each(function ($item) {
    $item->sizes->each->setAppends(['addons']);
});