为了账号安全,请及时绑定邮箱和手机立即绑定

这种雄辩方法的查询范围?

这种雄辩方法的查询范围?

PHP
慕尼黑8549860 2023-08-06 15:39:13
我在我的项目中创建了一个过滤方法,我使用此方法过滤了数据,但现在我想使用 laravel 中的 queryScope 方法重构代码,任何人都可以建议我如何重构此代码。这段代码运行良好。这是我的控制器索引方法    public function index(Request $request)    {        $status = Ticket_status::pluck('name');        $tickets = Ticket::with('users','ticketStatus','ticketType','tbl_contacts')                    ->where('user_id','=',Auth::user()->id)                    ->latest();        if (request('Open')) {            $tickets = $tickets->where('status_id',1)->get();        } elseif (request('Pending')) {            $tickets = $tickets->where('status_id',2)->get();        } elseif (request('Close')) {            $tickets = $tickets->where('status_id',3)->get();        } else {            $tickets = $tickets->get();        }        return view('ticketing.user.index',compact('tickets','status'));    }这是我的刀片文件..在这个文件中,所有代码都运行良好,但我想进行一些重构<div class="col-md-8">                            <a                                href="{{route('tickets.index')}}"                                class="btn btn-sm btn-outline-secondary mr-1">                                All                            </a>                            @foreach ($status as $status_name)                                <a                    href="/tickets?{{Str::lower($status_name)}}={{ Str::lower($status_name) }}"                     class="btn btn-sm btn-outline-secondary mr-1">                                    {{$status_name}}                                </a>                            @endforeach                          </div>
查看完整描述

1 回答

?
Helenr

TA贡献1780条经验 获得超3个赞

您可以local在模型上定义范围来重构查询。以下是一些:


class Ticket extends Model

{

use SoftDeletes;


public function scopeByAuthUser($query)

{

    return $query->where('user_id','=', \Auth::user()->id);

}


public function scopeOpen($query)

{

    return $query->where('status_id', 1);

}


public function scopePending($query)

{

    return $query->where('status_id', 2);

}


public function scopeClose($query)

{

    return $query->where('status_id', 2);

}



 

}

以下是重构您的条件的方法:


 // for the first query

 $tickets = Ticket::with('users','ticketStatus','ticketType','tbl_contacts')

                ->byAuthUser()

                ->latest();


 if(request('Open') || request('Pending') || request('Close')) {

   $scope = strtolower(request('Open') ?? request('Pending') ?? request('Close'));

   $tickets = $tickets->{$scope}()->get();

 } else {

  $tickets = $tickets->get();

 }


查看完整回答
反对 回复 2023-08-06
  • 1 回答
  • 0 关注
  • 76 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信