嗨,关于依赖注入的快速问题
我正在使用symfony 3并且正在接受DI
假设我有一堂课
use Doctrine'ORM'EntityManagerInterface;
class CommonRepository
{
/**
* @var EntityManagerInterface
*/
protected $em;
/**
* DoctrineUserRepository constructor.
* @param EntityManagerInterface $em
*/
public function __construct(EntityManagerInterface $em)
{
$this->em = $em;
}
public function getEntityManager()
{
return $this->em;
}
}
现在一个名为UserRepository的新类,我注入了上面的类,这是否意味着我可以访问注入的项目注入的项目(显然他在开始结束时做梦)?
class UserRepository
{
/**
* @var CommonDoctrineRepository
*/
private $commonRepository;
/**
* @var 'Doctrine'ORM'EntityManagerInterface
*/
private $em;
/**
* DoctrineUserRepository constructor.
* @param CommonRepository $CommonRepository
*/
public function __construct(CommonRepository $CommonRepository)
{
$this->commonRepository = $commonRepository;
$this->em = $this->commonRepository->getEntityManager();
}
public function find($id)
{
//does not seem to work
//return $em->find($id);
//nor does
//return $this->em->find($id);
}
}
即使我扩展班级,然后试图构建父母没有快乐,显然我可以注入教义经理进入用户存储库,我只是想对 DI 和继承有所了解
class UserRepository extends CommonRepository
{
/**
* @var CommonDoctrineRepository
*/
private $commonRepository;
/**
* @var 'Doctrine'ORM'EntityManagerInterface
*/
private $em;
public function __construct(CommonDoctrineRepository $commonRepository, $em)
{
parent::__construct($em);
$this->commonRepository = $commonRepository;
}
}
对于symfony组件,我已经定义了这样的服务
app.repository.common_repository:
class: AppBundle'Repository'Doctrine'CommonRepository
arguments:
- "@doctrine.orm.entity_manager"
app.repository.user_repository:
class: AppBundle'Repository'Doctrine'UserRepository
arguments:
- "@app.repository.common_repository"
依赖注入只是将对象传递到构造函数(或setter方法)的过程。依赖注入容器(或服务容器)只不过是将正确的对象实例注入构造函数的帮助程序。
话虽如此,很明显依赖注入不会以任何方式影响PHP(顺便说一句,Symfony中没有任何内容,它只是普通的PHP内容)。
因此,继承就像它适用于一些普通的PHP对象一样(这是一个奇怪的比较,因为它们已经是普通的PHP对象)。
这意味着,如果CommonRepository#getEntityManager()
是公共的并且CommonRepository
已正确实例化,则此方法应返回传递给其构造函数的实体管理器。
这同样适用于UserRepository
:如果将传递的CommonRepository#getEntityManager()
实例保存在 $em
属性中,则所有方法都可以使用此$em
属性访问实体管理器。这意味着做$this->em->find(...)
应该完美地工作($em->find(...)
不应该,因为没有$em
变量)。
tl;dr:你在问题中展示的代码(除了奇怪的扩展示例)运行良好。