在控制器上避免使用Laravel外观

时间:2018-03-06 19:19:56

标签: php laravel

我正在使用Laravel 5.5并尝试习惯psr-2 standard的代码(刚刚开始学习)。我用Quafoo QA分析了我的所有代码,并逐步修复错误并记录下来。

通过使用外墙,我收到此错误"Avoid using static access to class"。因此,我试图避免使用它们 在我的控制器上我有这段代码:

<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;
use App\Events\FileLoaded;
use Illuminate\Support\Facades\Input;
use Illuminate\Auth\Middleware\Authenticate;
use PhpOffice\PhpSpreadsheet\Shared\StringHelper;
use \Illuminate\Contracts\View\Factory as ViewFactory;

class LoadDataController extends Controller
{

    public function index()
    {
        $viewfactory = app(ViewFactory::class);
        return $viewfactory->make('LoadData/index');
    }

    //more code
}

除了View Facade我还使用DB, Input, Validator and Storage 这是正确的方法,还有其他人吗?

1 个答案:

答案 0 :(得分:5)

您无需避免Facades - 它们是框架的关键部分。但是如果你愿意,你可以使用依赖注入来包含你需要的类作为控制器方法中的参数:

class LoadDataController extends Controller
{

  public function index(ViewFactory $viewFactory)
  {
    return $viewfactory->make('LoadData/index');
  }

  //more code
}

或者如果您在所有控制器方法中都需要它:

class LoadDataController extends Controller
{
  private $viewFactory;

  public function __construct(ViewFactory $viewFactory)
  {
    $this->viewFactory = $viewFactory;
  }

  public function index()
  {
    return $this->viewFactory->make('LoadData/index');
  }

  //more code
}

当然,这实际上并没有改变您编写的代码的功能,只是重新排列它。我不会把你提到的代码分析器的话当作你做错的事。这些是在Laravel中使用的标准模式。