Laravel Advanced Dimana cara melewatkan variabel ke dalam fungsi?

87

Contoh di doc:

DB::table('users')
        ->whereExists(function($query)
        {
            $query->select(DB::raw(1))
                  ->from('orders')
                  ->whereRaw('orders.user_id = users.id');
        })
        ->get();

Tetapi bagaimana jika saya perlu menggunakan variabel eksternal seperti itu:

            ->where('city_id', '=', $this->city->id)
            ->where(function($query)
                {
                    $query->where('name', 'LIKE', '%'.$searchQuery.'%')
                    ->orWhere('address', 'LIKE', '%'.$searchQuery.'%')

                })

Untuk saat ini saya membuat properti baru dan mengaksesnya $this->, tetapi apakah ada cara yang lebih nyaman?

kegilaan
sumber

Jawaban:

230

Anda dapat meneruskan variabel yang diperlukan dari lingkup induk ke closure dengan usekata kunci.

Sebagai contoh:

DB::table('users')->where(function ($query) use ($activated) {
    $query->where('activated', '=', $activated);
})->get();

Lebih lanjut tentang itu di sini .

EDIT (pembaruan 2019):

PHP 7.4 (akan dirilis pada 28 November 2019 ) memperkenalkan variasi yang lebih pendek dari fungsi anonim yang disebut fungsi panah yang membuatnya sedikit kurang bertele-tele.

Contoh menggunakan PHP 7.4 yang secara fungsional hampir setara (lihat poin ke-3 di bawah):

DB::table('users')->where(fn($query) => $query->where('activated', '=', $activated))->get();

Perbedaan dibandingkan dengan sintaks biasa:

  • fnkata kunci, bukan function.
  • Tidak perlu secara eksplisit mencantumkan semua variabel yang harus diambil dari lingkup induk - ini sekarang dilakukan secara otomatis menurut nilai. Lihat kekuranganuse kata kunci di contoh terakhir.
  • Fungsi panah selalu mengembalikan nilai. Ini juga berarti bahwa tidak mungkin menggunakan voidtipe kembalian saat mendeklarasikannya.
  • Kata returnkunci harus dihilangkan.
  • Fungsi panah harus memiliki ekspresi tunggal yang merupakan pernyataan return. Fungsi multi-garis tidak didukung saat ini. Anda masih bisa menggunakan metode berantai.
kajetons
sumber
15

Jawaban @kajetons berfungsi penuh.

Anda juga bisa melewatkan banyak variabel dengan meneruskannya seperti: use($var1, $var2)

DB::table('users')->where(function ($query) use ($activated,$var2) {
    $query->where('activated', '=', $activated);
    $query->where('var2', '>', $var2);
})->get();
Nagibaba
sumber
5

Jika Anda menggunakan Laravel dengan fasih Anda dapat mencoba ini juga.

$result = self::select('*')
                    ->with('user')
                    ->where('subscriptionPlan', function($query) use($activated){
                        $query->where('activated', '=', $roleId);
                    })
                    ->get();
Nikunj K.
sumber
2

Anda dapat melewatkan variabel menggunakan ini ...

$status =1;
 $info = JOBS::where(function($query) use ($status){        
         $query->where('status',$status);
         })->get();
print_r($info);
Ajay Singh
sumber