Laravel Advanced Gdzie jak przekazać zmienną do funkcji?

86

Przykład w dokumencie:

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

Ale co, jeśli potrzebuję takiej zmiennej zewnętrznej:

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

                })

Na razie utworzyłem nową nieruchomość i uzyskałem do niej dostęp $this->, ale czy istnieje wygodniejszy sposób?

szał
źródło

Odpowiedzi:

225

Niezbędne zmienne z zakresu nadrzędnego można przekazać do zamknięcia za pomocą usesłowa kluczowego.

Na przykład:

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

Więcej na ten temat tutaj .

EDYCJA (aktualizacja 2019):

PHP 7.4 (zostanie wydane 28 listopada 2019 r. ) Wprowadza krótszą odmianę funkcji anonimowych zwanych funkcjami strzałkowymi, co sprawia, że ​​jest to nieco mniej rozwlekłe.

Przykład używający PHP 7.4, który jest funkcjonalnie prawie równoważny (zobacz trzeci punkt poniżej):

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

Różnice w porównaniu ze zwykłą składnią:

  • fnsłowo kluczowe zamiast function.
  • Nie trzeba jawnie wymieniać wszystkich zmiennych, które powinny zostać przechwycone z zakresu nadrzędnego - jest to teraz wykonywane automatycznie według wartości. Zobacz brak usesłowa kluczowego w drugim przykładzie.
  • Funkcje strzałkowe zawsze zwracają wartość. Oznacza to również, że voidprzy ich deklarowaniu nie można używać zwracanych typów.
  • Słowo returnkluczowe należy pominąć.
  • Funkcje strzałkowe muszą mieć jedno wyrażenie, którym jest instrukcja return. Obecnie funkcje wieloliniowe nie są obsługiwane. Nadal możesz jednak łączyć metody.
kajetons
źródło
15

Odpowiedź @kajetons jest w pełni funkcjonalna.

Możesz również przekazać wiele zmiennych, przekazując je, na przykład: use($var1, $var2)

DB::table('users')->where(function ($query) use ($activated,$var2) {
    $query->where('activated', '=', $activated);
    $query->where('var2', '>', $var2);
})->get();
Nagibaba
źródło
5

Jeśli używasz Laravel eloquent, możesz spróbować również tego.

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

Możesz przekazywać zmienne za pomocą tego ...

$status =1;
 $info = JOBS::where(function($query) use ($status){        
         $query->where('status',$status);
         })->get();
print_r($info);
Ajay Singh
źródło