亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

這種雄辯方法的查詢范圍?

這種雄辯方法的查詢范圍?

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條經驗 獲得超4個贊

您可以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 關注
  • 112 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號