我正在使用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
这是正确的方法,还有其他人吗?
答案 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中使用的标准模式。