Dalam artikel ini, Kami sedang melaksanakan laravel fasih apabila keadaan. Dalam proses penapisan keluar, kami menggunakan syarat if-else atas permintaan. Semak kod di bawah.
if($request->filter_by == 'amount') { $query->where('amount', '>', request('amount', 0)); } if($request->filter_by == 'created_at') { $query->orderBy('created_at', request('order', 'desc')); }
Anda boleh menggunakan kaedah bila(). Ia lebih mudah dibaca dan mesra pengguna. Semak kod di bawah.
$query = Order::query(); $query->when(request('filter_by') == 'amount', function($q){ return $q->where('amount','>', request('amount',0)); }); $query->when(request('filter_by') == 'created_at', function($q){ return $q->orderBy('created_at', request('order','desc')); });
Anda boleh menghantar hujah ketiga kepada kaedah bila. Penutupan ini hanya akan dilaksanakan jika argumen pertama dinilai sebagai palsu.
$query = Order::query(); $query->when(request('filter_by') == 'amount', function($q){ return $q->where('amount','>', request('amount',0)); }, function($q){ return $q->orderBy('created_at', request('order','desc')); })->get();
Ini bukan sahaja cara yang lebih cantik untuk menulis "JIKA" yang sama tetapi juga merupakan cara yang bagus untuk mengatur pertanyaan bersyarat.
Anda boleh membaca lebih lanjut tentang jenis artikel ini di tapak
Atas ialah kandungan terperinci Cara menggunakan fasih apabila dalam laravel. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!