dongxie7683 2017-01-09 21:48
浏览 115
已采纳

如何将变量传递给Laravel 5.3中的内部函数?

I am trying to pass the locale data to the eloquent query but it cannot get it. $locale value is taken from the URI.

class MyController extends Controller
{

    public function index($locale = 'en')
    {
        $news = News::join('categories', 'categories.id', '=', 'news.catid')
            ->select('news.*', 'categories.category')
            ->where([['news.published', '1'], ['news.deleted', '0']])
            ->where(function ($query) {
                $query->where('news.language', $locale) //$locale is not recognized naturally
                      ->orWhere('news.language', 'all');
            })
            ->orderBy('news.published_at', 'desc')
            ->take(4)
            ->get();

             .
             .
             .
    }
}

How can I pass $locale value into the subquery?

  • 写回答

1条回答 默认 最新

  • duanpin2034 2017-01-09 21:50
    关注

    There is the use construct that you can use to create a closure around the variable:

    ->where(function ($query) use($locale) {
        $query->where('news.language', $locale) 
              ->orWhere('news.language', 'all');
    })
    

    See Example #3 in the manual, "Inheriting variables from the parent scope".

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 metadata提取的PDF元数据,如何转换为一个Excel
  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错
  • ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
  • ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
  • ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同
  • ¥50 如何openEuler 22.03上安装配置drbd
  • ¥20 ING91680C BLE5.3 芯片怎么实现串口收发数据
  • ¥15 无线连接树莓派,无法执行update,如何解决?(相关搜索:软件下载)
  • ¥15 Windows11, backspace, enter, space键失灵