7个项目
而且我拥有Voucher_detale
模型的全局范围
<?php
namespace App\Scopes;
use Illuminate\Database\Eloquent\Scope;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\Builder;
class getVouchers implements Scope
{
public function apply(Builder $builder, Model $model)
{
$builder->where('vouchers_detale_state', '=', 1);
}
}
我有Voucher
模型,里面有hasMany,这是代码'
public function getDetales()
{
return $this->hasMany('App\Vouchers_detale','vouchers_detale_voucher_id','id')->withTrashed();
}
刀片里面我有此代码
@foreach($voucher['getDetales'] as $v)
<tr class='table-warning'>
<td>
<a href='/{{$path}}/Vouchers_detales/{{$v["id"]}}'>{{$v['vouchers_detale_user_id']}}</a>
<div class='selected d-print-none'>
@foreach($v->getUpdate as $update)
<span style='color:black'>{{$update['update_history_old_amount']}}</span>
{{$update['created_at']}}
{{$update['getUserData']['user_name']}}
<hr />
@endforeach
</div>
</td>
<td>{{$v['getUserData']['user_name']}}</td>
@if($v['vouchers_detale_amount'] > 0)
<td>{{$v['vouchers_detale_amount']}}</td>
<td></td>
@php $total_debt += $v['vouchers_detale_amount'] @endphp
@else
<td></td>
<td>{{$v['vouchers_detale_amount'] * -1}}</td>
@php $total_credit += $v['vouchers_detale_amount'] * -1 @endphp
@endif
<td>{{$v['vouchers_detale_desc']}}</td>
</tr>
@endforeach
现在我该如何在尝试过的foreach中忽略全局范围
@foreach($voucher['getDetales']->withoutGlobalScopes() as $v)
我错了
Method Illuminate\Database\Eloquent\Collection::withoutGlobalScopes does not exist.
我怎么能忽略来自foreach中关系的全局范围 谢谢
答案 0 :(得分:0)
没关系,我刚刚创建了新关系
public function getDetalesWithout()
{
return $this->hasMany('App\Vouchers_detale','vouchers_detale_voucher_id','id')->withTrashed()->withoutGlobalScope('App\Scopes\getVouchers');
}
谢谢