Laravel Advanced何处将变量传递给函数?


86

doc中的示例:

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->,但是还有其他更便捷的方法吗?

Answers:


225

您可以使用use关键字将必要的变量从父范围传递到闭包中。

例如:

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

这里更多。

编辑(2019更新):

PHP 7.4(将于2019年11月28日发布)引入了一种称为箭头函数的匿名函数的较短变体,这使得它的冗长程度有所降低。

使用PHP 7.4的示例在功能上几乎等效(请参见下面的第3个要点):

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

与常规语法相比的差异:

  • fn关键字代替function
  • 无需显式列出应从父级作用域捕获的所有变量-现在可以自动按值完成。见缺乏use后面的示例中关键字。
  • 箭头函数始终返回一个值。这也意味着void在声明它们时不能使用返回类型。
  • return关键字必须被省略。
  • 箭头函数必须具有单个表达式,即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,也可以尝试使用。

$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);
By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.