Laravel Advanced Где, как передать переменную в функцию?

86

Пример в документе:

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

Но что, если мне нужно использовать такую ​​внешнюю переменную:

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

                })

На данный момент я создал новое свойство и получил к нему доступ $this->, но есть ли более удобный способ?

безумие
источник

Ответы:

225

Вы можете передать необходимые переменные из родительской области в замыкание с помощью useключевого слова.

Например:

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

Подробнее об этом здесь .

РЕДАКТИРОВАТЬ (обновление 2019):

PHP 7.4 (будет выпущен 28 ноября 2019 г. ) представляет более короткий вариант анонимных функций, называемых стрелочными функциями, что делает его немного менее подробным.

Пример использования PHP 7.4, который функционально почти эквивалентен (см. Третий пункт ниже):

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

Отличия от обычного синтаксиса:

  • fnключевое слово вместо function.
  • Нет необходимости явно перечислять все переменные, которые должны быть захвачены из родительской области - теперь это делается автоматически по значению. Посмотрите на отсутствие useключевого слова в последнем примере.
  • Стрелочные функции всегда возвращают значение. Это также означает, что voidпри их объявлении невозможно использовать возвращаемый тип.
  • returnКлючевое слово должно быть опущено.
  • Стрелочные функции должны иметь одно выражение, которое является оператором возврата. Многострочные функции в данный момент не поддерживаются. Однако вы все еще можете объединить методы.
каджетоны
источник
15

Ответ @kajetons полностью функциональный.

Вы также можете передать несколько переменных, передав их, например: use($var1, $var2)

DB::table('users')->where(function ($query) use ($activated,$var2) {
    $query->where('activated', '=', $activated);
    $query->where('var2', '>', $var2);
})->get();
Нагибаба
источник
5

Если вы используете Laravel eloquent, вы также можете попробовать это.

$result = self::select('*')
                    ->with('user')
                    ->where('subscriptionPlan', function($query) use($activated){
                        $query->where('activated', '=', $roleId);
                    })
                    ->get();
Никундж К.
источник
2

Вы можете передавать переменные, используя это ...

$status =1;
 $info = JOBS::where(function($query) use ($status){        
         $query->where('status',$status);
         })->get();
print_r($info);
Аджай Сингх
источник